1 10 5 1 5 100 3 10 10 5 10 100 1 4 2 6 12 266
102
这是一道比较基础的DP,我们把各个区间的收益按最大的存,DP[i]存放从0~i时刻的最大收益
#include <stdio.h> #include <string.h> #include <algorithm> using namespace std; int main() { int n,m,i,j,t; int a[105][105],dp[105]; scanf("%d",&t); while(t--) { memset(a,0,sizeof(a)); memset(dp,0,sizeof(dp)); scanf("%d%d",&n,&m); for(i = 1;i<=m;i++) { int x,y,c; scanf("%d%d%d",&x,&y,&c); a[x][y] = max(a[x][y],c); } for(i = 1;i<=n;i++) { for(j = i;j>=1;j--) dp[i] = max(dp[i],dp[j-1]+a[j][i]);//0~j-1时刻最大收益加上j~i时刻的收益 } printf("%d\n",dp[n]); } return 0; }
HDU4502:吉哥系列故事——临时工计划(DP),布布扣,bubuko.com
原文:http://blog.csdn.net/libin56842/article/details/20001231