博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【洛谷习题】尼克的任务
阅读量:4701 次
发布时间:2019-06-09

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

坑!

题目链接:


 

哎呀呀,好好的一道DP题,太伤心了。。。

思路很快有了,可以定义dp[i]为以第i个任务为结尾的方案中,花费时间最短的。从小到大枚举j,要求满足p[j]+t[j]<=p[i]&&p[j]+t[j]>p[last](last是指上一个与第i个任务时间不同的任务),然后dp[i]=min(dp[i],dp[j]+t[i]),一开始把dp初始化为inf。在最后应加上第k+1个任务,开始时间为n+1,持续时间为0(注意理清时间点和时间段)。这些都还不算什么,最坑的是我交上去只有30分,死活不知道哪错了,下载了个数据一看,原来最初几个任务的开始时间可以不是1(要先将最开始几个任务初始化,在最前面添加一个点的方式或许也可以躲开坑)!!!

这就涉及到思维问题了,是关注具体的值,还是抽象的关系。。。

1 #include 
2 #include
3 #include
4 5 using namespace std; 6 7 const int maxk = 1e4 + 5, inf = 0x3f3f3f3f; 8 9 int p[maxk], t[maxk], dp[maxk];10 11 int main() {12 int n, k;13 scanf("%d%d", &n, &k);14 memset(dp, inf, sizeof(dp));15 p[k + 1] = n + 1;16 for (int i = 1; i <= k + 1; ++i) {17 if (i <= k) scanf("%d%d", &p[i], &t[i]);18 if (p[i] == p[1]) {19 dp[i] = t[i];20 continue;21 }22 int last = i - 1;23 while (p[last] == p[i]) --last;24 for (int j = 0; j < i; ++j)25 if (p[j] + t[j] <= p[i] && p[j] + t[j] > p[last])26 dp[i] = min(dp[i], dp[j] + t[i]);27 }28 printf("%d", n - dp[k + 1]);29 return 0;30 }
AC代码

 

转载于:https://www.cnblogs.com/Mr94Kevin/p/9600166.html

你可能感兴趣的文章
OnePage收集
查看>>
Java parseInt()方法
查看>>
yahoo的30条优化规则
查看>>
[CCF2015.09]题解
查看>>
[NYIST15]括号匹配(二)(区间dp)
查看>>
json_value.cpp : fatal error C1083: 无法打开编译器生成的文件:No such file or directory
查看>>
洛谷 P1101 单词方阵
查看>>
Swift DispatchQueue
查看>>
C#和JAVA 访问修饰符
查看>>
小甲鱼OD学习第1讲
查看>>
HDU-1085 Holding Bin-Laden Captive-母函数
查看>>
php提示undefined index的几种解决方法
查看>>
LRJ
查看>>
Struts2环境搭建
查看>>
Linux: Check version info
查看>>
stl学习之测试stlen,cout等的运行速度
查看>>
魔戒三曲,黑暗散去;人皇加冕,光明归来
查看>>
Error和Exception
查看>>
Python和Singleton (单件)模式[转载]
查看>>
httpclient设置proxy与proxyselector
查看>>