关闭

HDU 1284 钱币兑换问题

标签: 算法ACM
40人阅读 评论(0) 收藏 举报
分类:

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是个神奇的东西

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:4079次
    • 积分:611
    • 等级:
    • 排名:千里之外
    • 原创:60篇
    • 转载:0篇
    • 译文:0篇
    • 评论:0条
    文章分类