hdu2063investment题解(完全背包)

原创 2016年05月30日 22:59:53

这道题需要一个小技巧,由于所有的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;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

HDU 2063 Investment 完全背包

Description John never knew he had a grand-uncle, until he received the notary's letter. He learn...

HDU2063:Investment-wust9(完全背包典型)

Problem C Time Limit : 5000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Tot...

poj2063 & hdu1963 Investment 又是DP啦,,经典完全背包问题

John never knew he had a grand-uncle, until he received the notary's letter. He learned that his lat...

HDU2063:Investment(完全背包)

Description John never knew he had a grand-uncle, until he received the notary's letter. He learned...

POJ 2063 Investment (完全背包)

Investment Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 7041   Accepted: 2447 ...

POJ 2063 Investment(完全背包)

POJ 2063 Investment(完全背包)        初始时有m (m

poj 2063& zoj 2224 Investment (多次完全背包)

Investment Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 3749   Acc...
  • fp_hzq
  • fp_hzq
  • 2011年10月02日 20:26
  • 1109

POJ 2063 Investment (完全背包)

哈哈这道题T了好多次了,各种T!不过思路很明确,完全背包的求解,这道题最大的优化就是债券的价钱是1000的整数倍。我其实一开始就想到了用这个优化,但是题目中没有说明给的总的钱数也是1000的整数倍,所...

Investment-----POJ_2063-----完全背包问题

题目地址:http://poj.org/problem?id=2063 Investment Time Limit: 1000MS   Memory Limit: 30...
  • dr5459
  • dr5459
  • 2012年07月19日 22:51
  • 803

POJ NO.2063 Investment(完全背包,典例)

问题描述: 给你一笔金额,你要将这比金额去投资,现在有t种股票,每种股票都有一个价值和年收益,问你如何投资在n年后的最大收益。 每一年投资后都要以利润连同本金继续投资下一年。 测试数据:   1   ...
  • quper1g
  • quper1g
  • 2016年03月05日 09:54
  • 320
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:hdu2063investment题解(完全背包)
举报原因:
原因补充:

(最多只允许输入30个字)