您的位置:首页 > 其它

hdu2063investment题解(完全背包)

2016-05-30 22:59 417 查看
这道题需要一个小技巧,由于所有的value都是multiple of 1000,所以将总钱数除以1000,每个value除以1000,将dp数组的大小降下来

状态转移方程:

dp[k]=Max(dp[k-bond1[j]]+bond2[j],dp[k]);

#include <stdio.h>
#include <string.h>
#define bttm 1000
#define M(X,Y) ((X)>(Y)?(X):(Y))
int bond1[12];
int dp[50050],bond2[12];
int main(int argc, char const *argv[])
{
int N,amnt,yr,i,num,j,k,tmp;
scanf("%d",&N);
while(N--)
{
scanf("%d %d",&amnt,&yr);
scanf("%d",&num);
for(i=0;i<num;i++)
{
scanf("%d %d",bond1+i,bond2+i);
bond1[i]/=bttm;
}
for(i=0;i<yr;i++)
{
tmp=amnt/bttm;
memset(dp,0,sizeof(dp));
for(j=0;j<num;j++)
{
for(k=bond1[j];k<=tmp;k++)
dp[k]=M(dp[k-bond1[j]]+bond2[j],dp[k]);
}
amnt+=dp[tmp];
}
printf("%d\n",amnt);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  dp hdu