Question:
Description
在一个国家仅有1分,2分,3分硬币,将钱N兑换成硬币有很多种兑法。请你编程序计算出共有多少种兑法。
Input
每行只有一个正整数N,N小于32768。
Output
对应每个输入,输出兑换方法数。
Sample Input
2934
12553
Sample Output
718831
13137761
思路:这是一个最简单的dp,只要找准转移方程,一般都是两层循环打表(1<=i<=3,i<=j<=n,dp[j]+=dp[j-i]这样打表清晰很多),就完全没有问题(开始自己也是找的规律)
(http://acm.hust.edu.cn/vjudge/contest/125402#problem/A)
#include <iostream>
#include <cstdio>
using namespace std;
typedef long long LL;
int n;
LL dp[35000];
int main()
{
dp[0]=0;
dp[1]=1;
dp[2]=2;
dp[3]=3;
dp[4]=4;
dp[5]=5; //这是自己先找到的规律
for(int i=6;i<35000;i++)
dp[i]=1+dp[i-2]-dp[i-2-3]+dp[i-3]; //dp[i-1]去掉与dp[i-2]和dp[i-3]重复的只剩下一个,dp[i-2]-dp[i-2-3]是去掉dp[i-2]与dp[i-3]重复的
while(~scanf("%d",&n))
printf("%lld\n",dp[n]);
}
体会:dp做多了会发现dp是个神奇的东西