【Codeforces 1129A】Toy Train
【链接】 我是链接,点我呀:)
【题意】
火车从1,2,3...n->1的方式绕圈走。(即每次从i走到i+1)
有一些点有货物需要装载,但是每个点只能装上去一个货物。
每个货物都有目标点卸货点(卸货的时候不限量)
问你假设火车起点为s(s=1,2,3...n)时,完成所有点的装货卸货任务需要的最小时间。
【题解】
会发现其实每个点出去的任务都是互相独立的。
某个点在做运载任务的时候,其他人也可以同时进行运载任务(路过了就捎上它的运载物就行,反正装运不需要时间)。
那么现在的问题仅仅是,让每个点完成所有任务的时间最短。
然后取所有点完成任务的时间中最长的那个作为答案就好了。
设第i个点的任务个数为cnt[i]
每个点i完成所有任务的时间为
起点s到i所需的时间+n*(cnt[i]-1)+cnt[i]个任务中所需时间最短的那个任务所用时间
前cnt[i]-1个任务肯定要绕cnt[i]-1圈然后回到原来的位置的.
最后一个任务才是关键,我们只要让最后一个任务的时间最短,那么肯定第i个点的所有任务完成的时间也就最短了。
【代码】
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N = 5000;
int n,m;
int mi[N+10],cnt[N+10];
int get_dis(int x,int y){
if (y>=x) return y-x;
else return y+n-x;
}
int main(){
ios::sync_with_stdio(0),cin.tie(0);
cin >>n >> m;
for (int i = 1;i <= m;i++){
int x,y;
cin >> x >> y;
cnt[x]++;
if (mi[x]==0)
mi[x]=get_dis(x,y);
else
mi[x] = min(mi[x],get_dis(x,y));
}
for (int i = 1;i <= n;i++){
int ans = 0;
for (int j = 1;j<=n;j++){
ans = max(ans,get_dis(i,j)+n*(cnt[j]-1)+mi[j]);
}
cout<<ans<<" ";
}
return 0;
}
【Codeforces 1129A】Toy Train的更多相关文章
- 【codeforces 415D】Mashmokh and ACM(普通dp)
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
- 【50.00%】【codeforces 602C】The Two Routes
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【33.33%】【codeforces 586D】Phillip and Trains
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【codeforces 707E】Garlands
[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...
- 【codeforces 707C】Pythagorean Triples
[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...
- 【codeforces 709D】Recover the String
[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...
- 【codeforces 709B】Checkpoints
[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...
- 【codeforces 709C】Letters Cyclic Shift
[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...
- 【Codeforces 429D】 Tricky Function
[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ...
随机推荐
- springboot开发过程中的小坑(持续更新)
1. 启动的Application必须放到一个package下面,如下: package com.example.kikidemo; import org.springframework.boot.S ...
- array_column() 函数[二维数组转为一维数组]
array_column() 函数 输出数组中某个键值的集合[二维数组转为一位数组] <?php // 表示由数据库返回的可能记录集的数组 $a = array( array( 'id' =&g ...
- ACM_走楼梯Ⅱ
走楼梯Ⅱ Time Limit: 2000/1000ms (Java/Others) Problem Description: 有一楼梯共N+1级,刚开始时你在第一级,若每次能走M级(1<=M& ...
- CSS之背景设置、字体设置、文本设置
<html> <head> <meta charset="utf-8"> <title>单行文本框与多行文本框</title& ...
- 375 Guess Number Higher or Lower II 猜数字大小 II
我们正在玩一个猜数游戏,游戏规则如下:我从 1 到 n 之间选择一个数字,你来猜我选了哪个数字.每次你猜错了,我都会告诉你,我选的数字比你的大了或者小了.然而,当你猜了数字 x 并且猜错了的时候,你需 ...
- .Net实战之反射操作篇
1.上一讲中描述了反射中常见的类,仅仅是描述类与反射之间的关系. 但是实际是对数据的操作, 在反射中,数据如何操作? [MyTable("T_UserInfo")] publ ...
- c++利用jsoncpp libcurl 构造http 包(原)
我们手游要接入uc九游进行测试,要用http向uc那边的sdk 服务器post json数据. 虽然他们提供了php,java还有c#的服务端demo,但是我们服务器是C++写的,我实在不想中间再转 ...
- bootstrap3无间距栅格/grid no-gutter
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- Android 仿 新闻阅读器 菜单弹出效果(附源码DEMO)
这一系列博文都是:(android高仿系列)今日头条 --新闻阅读器 (一) 开发中碰到问题之后实现的,觉得可能有的开发者用的到或则希望独立成一个小功能DEMO,所以就放出来这么一个DEMO. 原本觉 ...
- python学习笔记(7)——集合(set)
关键词#1.定义:无序不重复元素集, 基本功能包括关系测试和消除重复元素. 2.关键词:类似dict.只有key无value.常用于集合类数学运算. 3.创建 s=set() #入参可以是list.t ...