tyvj 1034 给你T的时间和N个任务的开始时间和完成所需时间,让你求最大的空闲时间
2010-11-13 09:19
211 查看
尼克每天上班之前都连接上英特网,接收他的上司发来的邮件,这些邮件包含了尼克主管的部门当天要完成的全部任务,每个任务由一个开始时刻与一个持续时间构成。 尼克的一个工作日为N分钟,从第一分钟开始到第N分钟结束。当尼克到达单位后他就开始干活。如果在同一时刻有多个任务需要完成,尼克可以任选其中的一个来做,而其余的则由他的同事完成,反之如果只有一个任务,则该任务必需由尼克去写成,假如某些任务开始时刻尼克正在工作,则这些任务也由尼克的同事完成。如果某任务于第P分钟开始,持续时间为T分钟,则该任务将在第P+T-1分钟结束。 写一个程序计算尼克应该如何选取任务,才能获得最大的空暇时间。 | ||
输入格式 Input Format | ||
输入数据第一行包含两个用空格隔开的整数N和K,1≤N≤10000,1≤K≤10000,N表示尼克的工作时间,单位为分,K表示任务总数。 接下来共有K行,每一行有两个用空格隔开的整数P和T,表示该任务从第P分钟开始,持续时间为T分钟,其中1≤P≤N,1≤P+T-1≤N。 | ||
输出格式 Output Format | ||
输出文件仅一行包含一个整数表示尼克可能获得的最大空暇时间。 | ||
样例输入 Sample Input | ||
15 6 1 2 1 6 4 11 8 5 8 1 11 5 | ||
样例输出 Sample Output | ||
4 | ||
#include<cstdio>
#include<cstring>
using namespace std;
int f[100000];//f[i]表示第i分钟后的最大空闲时间,结果为f[1]
int n,k;
int s[100000],t[100000];
int main()
{
while(scanf("%d%d",&n,&k)==2)
{
memset(f,0,sizeof(f));
for(int i=1;i<=k;i++) scanf("%d%d",&s[i],&t[i]);//已经按照s[i]排序
for(int i=n,j=k;i>=1;i--)
{
if(i!=s[j]) f[i]=f[i+1]+1;//如果第i分钟没有任务
else //如果第i分钟有任务
{
while(i==s[j])//f[i]等于做了这个任务后最大的空闲时间
{
if(f[i]<f[i+t[j]]) f[i]=f[i+t[j]];
j--;
}
}
}
printf("%d/n",f[1]);
}
return 0;
}
相关文章推荐
- 任务开始时间和完成时间
- 【代码笔记】获取系统完成任务所需的后台时间
- 车间任务不可更改开始时间/完成时间
- 【代码笔记】iOS-获取系统完成任务所需的后台时间
- 任务开始时间和完成时间
- Spark Mllib里如何记录开始训练时间、完成训练时间、所需训练时间(图文详解)
- 武汉大学计算机系。武汉大学是当时国内最早一批实施学分制的大学,按照学校要求,只要修完一定的学分就可以毕业。刚上大学,对自己要求比较严的雷军就开始选修了不少高年级的课程。仅用了两年时间,雷军修完了所有学分,甚至完成了大学的毕业设计。
- 大家都说是水题。。好吧,那我就从水题开始做。。自己独立的做。正好最近在辅导大二的数据结构,自己也加强下对栈的理解和应用。 第一次那么完全的独立完成OJ的题,激动呐!读题目理解就废了我好多的时间,虽说英语过了
- 【tyvj1034】尼克的任务
- 完成任务,开始blog
- 程序被送入后台后,向 iOS 借时间,完成长期任务-备
- 4程序员小飞原计划三天完成某个任务,现在是第三天的下午,他马上就可以做完。但是在实现功能的过程中,他越来越意识到自己原来设计中的弱点,他应该采取另一个办法,才能避免后面集成阶段的额外工作。但是他如果现在就改弦更张,那势必要影响自己原来估计的准确性,并且会花费额外的时间,这样他的老板、同事也许会因此看不起他。如果他按部就班地按既定设计完成,还要花更多时间在后续集成上,但那就不是他个人的问题了,怎么办
- tyvj1034 尼克的任务 (动态规划+链表)
- 数据库空闲连接超过最大wai_timemout时间,数据库会强行断开空闲的链接,dbcp解决方案
- TYVJ 1034 尼克的任务
- 任务-【完成时间】-2014年6月12日
- hdu 3433 A Task Process N个人,第i个人完成一个A任务需要时间ai,完成一个B任务需要时间bi, 现在又X个任务A和Y个任务B,求完成所有任务所需要的最短时间。
- 有个需求 除去周六,周日的时间,工作时间以早上8点半到下午五点半,9小时,以现在时间为起始时间,给一个完成任务需要时间参数x小时 用个方法实现推动几月几号完成,这个方法好实现吗
- 根据给定起止时间,完成下载任务(大概类似于日历日程这种)
- [ACM_水题] UVA 11729 Commando War [不可同时交代任务 可同时执行 最短完成全部时间 贪心]