poj 3616 Milking Time DP
来源:互联网 发布:神州数码医疗科技知乎 编辑:程序博客网 时间:2024/05/19 12:17
还是一道《挑战程序设计竞赛》上的基础题目
题目大意:
给一头奶牛挤奶,一共在N时间内,奶牛能下M次奶,但是每次挤完,都要休息R分钟才能接着挤,每次下的奶的数量不一样,给出每次下奶的时间段,和下奶量,求如何能让挤出的奶最多
思路:
可以直接把R加到y上,相当于结束时间直接加上休息时间。首先还是按照初始时间排序,然后把dp数组都初始化为在每个时间点能挤的奶量。dp[i]表示挤到牛第i次下奶的时候的最大量是多少(有时候可能被略过,所以这个还不是最终的最大值,最后还要比较一下dp[i],i from 1 to end,来确定ans),更新的时候dp[i]=max(dp[i],dp[j]+A[i].v);其中j要满足,第j次挤完能赶上第i次下奶即if(A[i].x>=A[j].y)
Sample Input
12 4 21 2 810 12 193 6 247 10 31
Sample Output
43
#include <iostream>#include <stdio.h>#include <math.h>#include <stdlib.h>#include <string>#include <string.h>#include <algorithm>#include <vector>#include <queue>#include <set>#include <map>#include <stack>using namespace std;typedef long long LL;const int INF=0x7fffffff;const int MAX_N=1009;int N,M,R,a,b,c;int dp[MAX_N];struct AA{ int x,y,v;} ;AA A[MAX_N];bool cmp(AA a,AA b){ if(a.x==b.x){ return a.y<b.y; } return a.x<b.x;}int main(){ cin>>N>>M>>R; for(int i=1;i<=M;i++){ scanf("%d%d%d",&A[i].x,&A[i].y,&A[i].v); A[i].y+=R; } sort(A+1,A+M+1,cmp);//第一次交忘了+1了,样例能过。。。WA了一次,坑了,怪我数组非要从1开始 for(int i=1;i<=M;i++){ dp[i]=A[i].v; } int ans=0; for(int i=1;i<=M;i++){ for(int j=1;j<=i;j++){ if(A[i].x>=A[j].y){ dp[i]=max(dp[i],dp[j]+A[i].v); } } ans=max(ans,dp[i]); } cout<<ans<<endl; return 0;}
0 0
- poj 3616 Milking Time DP
- POJ 3616 Milking Time DP
- poj-3616 Milking Time 【DP】
- poj 3616 Milking Time DP
- DP-POJ-3616-Milking Time
- poj 3616 Milking Time 【dp】
- [POJ 3616]Milking Time[DP]
- Poj 3616 Milking Time【dp】
- POJ - 3616 Milking Time(Dp)
- POJ 3616 Milking Time (DP)
- poj 3616 Milking Time (DP)
- [ poj 3616] Milking Time [ DP ]
- POJ 3616 Milking Time(简单DP)
- POJ 3616-Milking Time (基础DP)
- POJ 3616 Milking Time DP题解
- POJ 3616 Milking Time DP题解
- poj 3616 Milking Time dp+树状数组
- POJ 3616 Milking Time (dp)
- Java JDBC和MySQL
- virtualBox虚拟机的一些配置
- 并查集入门
- ORACLE_基础十二(Profiles)
- BUPT OJ 147. Substring
- poj 3616 Milking Time DP
- a new client --- using httpclient or curl or requests
- hibernate基于hql的基本查询
- 未文档化函数ObReferenceObjectByName的说明
- ajax无刷新实时验证用户名密码
- 实现的局域网内大文件传输(ftp功能)
- The Center of Gravity hdu2105
- Linux下多线程查看工具(pstree、ps、pstack)
- Java SE知识梳理