博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷P1280 尼克的任务[DP]
阅读量:7239 次
发布时间:2019-06-29

本文共 1385 字,大约阅读时间需要 4 分钟。

题目描述

尼克每天上班之前都连接上英特网,接收他的上司发来的邮件,这些邮件包含了尼克主管的部门当天要完成的全部任务,每个任务由一个开始时刻与一个持续时间构成。

尼克的一个工作日为N分钟,从第一分钟开始到第N分钟结束。当尼克到达单位后他就开始干活。如果在同一时刻有多个任务需要完戍,尼克可以任选其中的一个来做,而其余的则由他的同事完成,反之如果只有一个任务,则该任务必需由尼克去完成,假如某些任务开始时刻尼克正在工作,则这些任务也由尼克的同事完成。如果某任务于第P分钟开始,持续时间为T分钟,则该任务将在第P+T-1分钟结束。

写一个程序计算尼克应该如何选取任务,才能获得最大的空暇时间。

输入输出格式

输入格式:

 

输入数据第一行含两个用空格隔开的整数N和K(1≤N≤10000,1≤K≤10000),N表示尼克的工作时间,单位为分钟,K表示任务总数。

接下来共有K行,每一行有两个用空格隔开的整数P和T,表示该任务从第P分钟开始,持续时间为T分钟,其中1≤P≤N,1≤P+T-1≤N。

 

输出格式:

 

输出文件仅一行,包含一个整数,表示尼克可能获得的最大空暇时间。

 

输入输出样例

输入样例#1:
15 61 21 64 118 58 111 5
输出样例#1:
4

跟模拟赛一道题类似,不过那道题的开始和结束是一个区间,但也保证了一个任务不会做多次 很普通的dp d[i]从i到n最大空闲时间 把任务按开始时间排序,因为是单调的,可以实现均摊O(1)转移
#include
#include
#include
#include
using namespace std;const int N=1e4+5,M=1e6,INF=1e9;typedef long long ll;inline int read(){ char c=getchar();int x=0,f=1; while(c<'0'||c>'9'){
if(c=='-')f=-1;c=getchar();} while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();} return x*f;}int n,m;struct task{ int s,t; bool operator <(const task &r)const{
return s
=1;i--){ int flag=0; while(p>=1&&a[p].s==i) d[i]=max(d[i],d[i+a[p].t]),flag=1,p--; if(!flag) d[i]=d[i+1]+1; }}int main(){ n=read();m=read(); for(int i=1;i<=m;i++){ a[i].s=read(); a[i].t=read(); } sort(a+1,a+1+m); dp(); printf("%d",d[1]);}

 

转载地址:http://alrfm.baihongyu.com/

你可能感兴趣的文章
extjs_08_界面布局
查看>>
卷积神经网络(CNN)代码实现(MNIST)解析
查看>>
git 在命令行与图形状态下使用详情
查看>>
爱上MVC~Web.Config的Debug和Release版本介绍
查看>>
linux操作系统中oracle数据库的密码过期问题解决
查看>>
Spring中Bean的五个作用域
查看>>
hadoop之 distcp(分布式拷贝)
查看>>
Java后端程序员1年工作经验总结
查看>>
使用Vundle管理配置Vim的插件
查看>>
JDBC连接池&DBUtils使用
查看>>
可以通过shadowserver来查看开放的mdns(用以反射放大攻击)——中国的在 https://mdns.shadowserver.org/workstation/index.html...
查看>>
IOS系统控件高度
查看>>
Flink - ResultPartition
查看>>
2017.10.09 穆瑞课KUKA机器人培训视频的感想
查看>>
Jsoup
查看>>
python中的中文编码问题
查看>>
安卓播放音频
查看>>
in linux system of ftp command
查看>>
Win API:之GetCurrentThread、GetCurrentThreadId、GetCurrentProcess、GetCurrentProcessId
查看>>
***PHP $_FILES函数详解 + PHP文件上传 move_uploaded_file() 参数的正确写法
查看>>