hdu1114 dp(完全背包)

题意:已知空钱罐质量和满钱罐质量(也就是知道钱罐里的钱的质量),知道若干种钱币每种的质量以及其价值,钱币都是无限个,问最少钱罐中有多少钱。

这个题在集训的时候学长给我们做过,所以你会做是应该的,由于已经有固定的质量,所以是必须正好放满的完全背包问题。然后```具体过程就不细讲了完全背包依旧是经典,你要是还不会就滚回去看背包九讲并且无颜见学长们了```

 

 1 #include<stdio.h>

 2 #include<string.h>

 3 #define min(a,b) a<b?a:b

 4 int p[502],w[502],dp[10010];

 5 

 6 int main(){

 7     int T;

 8     while(scanf("%d",&T)!=EOF){

 9         for(int q=1;q<=T;q++){

10             memset(dp,-1,sizeof(dp));

11             int E,F,N;

12             dp[0]=0;

13             scanf("%d%d%d",&E,&F,&N);

14             int i,j,k,w0=F-E;

15             for(i=1;i<=N;i++){

16                 scanf("%d%d",&p[i],&w[i]);

17                 for(j=w[i];j<=w0;j++){

18                     if(dp[j-w[i]]>=0){

19                         if(dp[j]>=0){

20                             dp[j]=min(dp[j],dp[j-w[i]]+p[i]);

21                         }

22                         else dp[j]=dp[j-w[i]]+p[i];

23                     }

24                 }

25             }

26             if(dp[w0]==-1)printf("This is impossible.\n");

27             else printf("The minimum amount of money in the piggy-bank is %d.\n",dp[w0]);

28         }

29     }

30     return 0;

31 }
View Code

 

你可能感兴趣的:(HDU)