关闭

hdu2063investment题解(完全背包)

标签: dphdu
98人阅读 评论(0) 收藏 举报
分类:

这道题需要一个小技巧,由于所有的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;
}
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:15888次
    • 积分:1191
    • 等级:
    • 排名:千里之外
    • 原创:108篇
    • 转载:4篇
    • 译文:0篇
    • 评论:5条
    最新评论