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