poj 3616 Milking Time DP
2015-04-05 19:30
274 查看
还是一道《挑战程序设计竞赛》上的基础题目
题目大意:
给一头奶牛挤奶,一共在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
Sample Output
题目大意:
给一头奶牛挤奶,一共在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 2 1 2 8 10 12 19 3 6 24 7 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; }
相关文章推荐
- poj 3616 Milking Time dp
- poj 3616 Milking Time dp
- POJ 3616 Milking Time——区间DP
- POJ 3616 B - Milking Time dp(深搜超时)
- Milking Time POJ - 3616 (简单dp)
- 【dp】Milking Time POJ - 3616
- POJ 3616 Milking Time DP
- POJ 3616 Milking Time DP
- Milking Time POJ - 3616
- Milking Time POJ - 3616
- hdu 3616 Milking Time dp 离散化
- Milking Time POJ - 3616
- Milking Time POJ - 3616
- Milking Time POJ - 3616
- POJ_3616_Milking_Time_(动态规划)
- 动态规划训练22 [Milking Time POJ - 3616 ]
- Milking Time POJ - 3616
- Milking Time POJ - 3616
- POJ 3616 Milking Time
- Milking Time POJ - 3616