背包解决硬币问题专题
来源:互联网 发布:parse解析json字符串 编辑:程序博客网 时间:2024/06/06 04:15
link:http://acm.hdu.edu.cn/showproblem.php?pid=1284
钱币兑换问题
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 6727 Accepted Submission(s): 3903
Problem Description
在一个国家仅有1分,2分,3分硬币,将钱N兑换成硬币有很多种兑法。请你编程序计算出共有多少种兑法。
Input
每行只有一个正整数N,N小于32768。
Output
对应每个输入,输出兑换方法数。
Sample Input
293412553
Sample Output
71883113137761
Author
SmallBeer(CML)
Source
杭电ACM集训队训练赛(VII)
AC code:
#include<iostream>#include<stdio.h>#include<map>#include<vector>#include<set>#include<cstdlib>#include<string.h>#include<string>#include<algorithm>#include<cmath>#define MAXN 1000010#define LL long long#define EPS 1e-9using namespace std;int dp[MAXN],c[MAXN];int main(){ int n,i,j; c[1]=1; c[2]=2; c[3]=3; while(~scanf("%d",&n)) { memset(dp,0,sizeof(dp)); dp[0]=1; for(i=1;i<=3;i++) { for(j=c[i];j<=n;j++) { dp[j]+=dp[j-c[i]]; } } printf("%d\n",dp[n]); } return 0;}
Link:http://acm.hdu.edu.cn/showproblem.php?pid=1028
Ignatius and the Princess III
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 14668 Accepted Submission(s): 10329
Problem Description
"Well, it seems the first problem is too easy. I will let you know how foolish you are later." feng5166 says.
"The second problem is, given an positive integer N, we define an equation like this:
N=a[1]+a[2]+a[3]+...+a[m];
a[i]>0,1<=m<=N;
My question is how many different equations you can find for a given N.
For example, assume N is 4, we can find:
4 = 4;
4 = 3 + 1;
4 = 2 + 2;
4 = 2 + 1 + 1;
4 = 1 + 1 + 1 + 1;
so the result is 5 when N is 4. Note that "4 = 3 + 1" and "4 = 1 + 3" is the same in this problem. Now, you do it!"
"The second problem is, given an positive integer N, we define an equation like this:
N=a[1]+a[2]+a[3]+...+a[m];
a[i]>0,1<=m<=N;
My question is how many different equations you can find for a given N.
For example, assume N is 4, we can find:
4 = 4;
4 = 3 + 1;
4 = 2 + 2;
4 = 2 + 1 + 1;
4 = 1 + 1 + 1 + 1;
so the result is 5 when N is 4. Note that "4 = 3 + 1" and "4 = 1 + 3" is the same in this problem. Now, you do it!"
Input
The input contains several test cases. Each test case contains a positive integer N(1<=N<=120) which is mentioned above. The input is terminated by the end of file.
Output
For each test case, you have to output a line contains an integer P which indicate the different equations you have found.
Sample Input
41020
Sample Output
542627
Author
Ignatius.L
#include<iostream>#include<stdio.h>#include<map>#include<vector>#include<set>#include<cstdlib>#include<string.h>#include<string>#include<algorithm>#include<cmath>#define MAXN 1000010#define LL long long#define EPS 1e-9using namespace std;int dp[MAXN],c[MAXN];int main(){int n,i,j;for(i=1;i<=122;i++)c[i]=i;while(~scanf("%d",&n)){memset(dp,0,sizeof(dp));dp[0]=1;for(i=1;i<=n;i++){for(j=c[i];j<=n;j++){dp[j]+=dp[j-c[i]];}}printf("%d\n",dp[n]);}return 0;}
Link:http://acm.hdu.edu.cn/showproblem.php?pid=1398
Square Coins
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 8983 Accepted Submission(s): 6135
Problem Description
People in Silverland use square coins. Not only they have square shapes but also their values are square numbers. Coins with values of all square numbers up to 289 (=17^2), i.e., 1-credit coins, 4-credit coins, 9-credit coins, ..., and 289-credit coins, are available in Silverland.
There are four combinations of coins to pay ten credits:
ten 1-credit coins,
one 4-credit coin and six 1-credit coins,
two 4-credit coins and two 1-credit coins, and
one 9-credit coin and one 1-credit coin.
Your mission is to count the number of ways to pay a given amount using coins of Silverland.
There are four combinations of coins to pay ten credits:
ten 1-credit coins,
one 4-credit coin and six 1-credit coins,
two 4-credit coins and two 1-credit coins, and
one 9-credit coin and one 1-credit coin.
Your mission is to count the number of ways to pay a given amount using coins of Silverland.
Input
The input consists of lines each containing an integer meaning an amount to be paid, followed by a line containing a zero. You may assume that all the amounts are positive and less than 300.
Output
For each of the given amount, one line containing a single integer representing the number of combinations of coins should be output. No other characters should appear in the output.
Sample Input
210300
Sample Output
1427
Source
Asia 1999, Kyoto (Japan)
AC code:
#include<iostream>#include<stdio.h>#include<map>#include<vector>#include<set>#include<cstdlib>#include<string.h>#include<string>#include<algorithm>#include<cmath>#define MAXN 1000010#define LL long long#define EPS 1e-9using namespace std;int dp[MAXN],c[MAXN];int main(){int n,i,j;for(i=1;i<=17;i++)c[i]=i*i;while(~scanf("%d",&n)&&n){memset(dp,0,sizeof(dp));dp[0]=1;for(i=1;i<=17;i++){for(j=c[i];j<=n;j++){dp[j]+=dp[j-c[i]];}}printf("%d\n",dp[n]);}return 0;}
Link:http://acm.hdu.edu.cn/showproblem.php?pid=2069
Coin Change
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 14976 Accepted Submission(s): 5066
Problem Description
Suppose there are 5 types of coins: 50-cent, 25-cent, 10-cent, 5-cent, and 1-cent. We want to make changes with these coins for a given amount of money.
For example, if we have 11 cents, then we can make changes with one 10-cent coin and one 1-cent coin, or two 5-cent coins and one 1-cent coin, or one 5-cent coin and six 1-cent coins, or eleven 1-cent coins. So there are four ways of making changes for 11 cents with the above coins. Note that we count that there is one way of making change for zero cent.
Write a program to find the total number of different ways of making changes for any amount of money in cents. Your program should be able to handle up to 100 coins.
For example, if we have 11 cents, then we can make changes with one 10-cent coin and one 1-cent coin, or two 5-cent coins and one 1-cent coin, or one 5-cent coin and six 1-cent coins, or eleven 1-cent coins. So there are four ways of making changes for 11 cents with the above coins. Note that we count that there is one way of making change for zero cent.
Write a program to find the total number of different ways of making changes for any amount of money in cents. Your program should be able to handle up to 100 coins.
Input
The input file contains any number of lines, each one consisting of a number ( ≤250 ) for the amount of money in cents.
Output
For each input line, output a line containing the number of different ways of making changes with the above 5 types of coins.
Sample Input
1126
Sample Output
413
Author
Lily
Source
浙江工业大学网络选拔赛
AC code:
#include<iostream>#include<stdio.h>#include<map>#include<vector>#include<set>#include<cstdlib>#include<string.h>#include<string>#include<algorithm>#include<cmath>#define MAXN 1000010#define LL long long#define EPS 1e-9using namespace std;int dp[333][333],c[MAXN];LL ans;int main(){int n,i,j,k;c[1]=50;c[2]=25;c[3]=10;c[4]=5;c[5]=1;while(~scanf("%d",&n)){memset(dp,0,sizeof(dp));dp[0][0]=1;for(i=1;i<=5;i++){for(k=0;k<=100;k++){for(j=c[i];j<=n;j++) { dp[j][k]+=dp[j-c[i]][k-1]; }}}ans=0;for(i=0;i<=100;i++){ans+=dp[n][i];}printf("%d\n",ans);}return 0;}
0 0
- 背包解决硬币问题专题
- 背包问题,硬币问题
- 背包的硬币问题
- 背包问题 - 硬币找零
- 背包问题-背包01-硬币找零
- 【专题】背包问题
- 最少硬币问题(多重背包问题)
- tyvj p1214硬币问题(完全背包)
- 硬币找零问题(完全背包)
- TYVJ-P1214 硬币问题-完全背包
- BToj 1030 硬币问题 【DP-完全背包】
- 动态规划解决硬币问题
- 分治解决假硬币问题
- 贪心法解决硬币问题
- 背包系列专题之完全背包问题
- nyoj 106 背包问题 (贪心 (硬币问题))
- 最少硬币问题(动态规划解决)
- 冯诺依曼解决的一个抛硬币问题
- 云核算广泛的使用场景发展意义
- Libevent源码分析-----内存分配
- Jump Game - LeetCode
- 算法--库函数实现全排列
- system.badimageformatexception 未能加载文件或程序集
- 背包解决硬币问题专题
- JAVA 集合类
- 如何进行用户体验的评估分析
- 进程与线程的区别与联系
- Objective-c基础
- day01总结
- Android性能优化典范
- 提高编程技能最有效的方法
- VC控制程序只运行一次效果