题意:已知空钱罐质量和满钱罐质量(也就是知道钱罐里的钱的质量),知道若干种钱币每种的质量以及其价值,钱币都是无限个,问最少钱罐中有多少钱。
这个题在集训的时候学长给我们做过,所以你会做是应该的,由于已经有固定的质量,所以是必须正好放满的完全背包问题。然后```具体过程就不细讲了完全背包依旧是经典,你要是还不会就滚回去看背包九讲并且无颜见学长们了```
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 }