HDU 1284 钱币兑换问题

原创 2016年08月29日 15:39:32

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

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

HDU 1284 钱币兑换问题 母函数、DP

HDU 1284 钱币兑换问题 母函数、DP

钱币兑换问题 HDU - 1284

Problem Description 在一个国家仅有1分,2分,3分硬币,将钱N兑换成硬币有很多种兑法。请你编程序计算出共有多少种兑法。 Input 每行只有一个正整数...

HDU 1284 钱币兑换问题

原题: http://acm.hdu.edu.cn/showproblem.php?pid=1284这题一看就是学c语言百钱买百鸡的问题,所以我的代码是这样的。#include #include"...

hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

对于初学者很好的解释了钱币兑换问题

HUD 1284 钱币兑换问题

HDU 1284 钱币兑换问题Problem Description在一个国家仅有1分,2分,3分硬币,将钱N兑换成硬币有很多种兑法。请你编程序计算出共有多少种兑法。Input每行只有一个正整数N,N...

完全背包之钱币兑换问题

钱币兑换问题 在一个国家仅有1分,2分,3分硬币,将钱N兑换成硬币有很多种兑法。请你编程序计算出共有多少种兑法。  输入:每行只有一个正整数N,N小于32768。 ...

钱币组合方法数的问题

8595 钱币组合方法数的问题时间限制:300MS  内存限制:1000K提交次数:43 通过次数:17题型: 编程题   语言: 无限制Description设有n种不同的纸币若干张,可用这n种钱币...

ACM动态规划之最少钱币问题

题目描述: 这是一个古老而又经典的问题。用给定的几种钱币凑成某个钱数,一般而言有多种方式。例 如:给定了 6 种钱币面值为 2、5、10、20、50、100,用来凑 15 元,可以用 5 个 2 元、...

8595 钱币组合方法数的问题

8595 钱币组合方法数的问题 时间限制:300MS  内存限制:1000K 题型: 编程题   语言: 无限制 Description 设有n种不同的钱币各若干,可用这n种钱币产生...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)