首页 > 其他 > 详细

子集和问题(应用--换零钱)

时间:2015-03-23 21:33:25      阅读:180      评论:0      收藏:0      [点我收藏+]

我一直在纠结换零钱这一类型的题目,今天好好絮叨一下,可以说他是背包的应用,也可以说他是单纯的dp。暂且称他为dp吧。

先上一道模板题目。

sdut2777: 小P的故事——神奇的换零钱

题目描述

已知A国经济很落后,他们只有1、2、3元三种面值的硬币,有一天小P要去A国旅行,想换一些零钱,小P很想知道将钱N兑换成硬币有很多种兑法,但是可惜的是他的数学竟然是体育老师教的,所以他不会啊、、、他只好求助于你,你可以帮他解决吗?

提示:输入数据大于32000组。

输入

 每行只有一个正整数N,N小于32768。

输出

 对应每个输入,输出兑换方法数。

示例输入

100 
1500

示例输出

884 
188251

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <queue>
#include <math.h>
#define inf 0x3f3f3f3f
typedef long long ll;
using namespace std;
int n,dp[32800],w[4];
int main()
{
    w[1]=1;
    w[2]=2;
    w[3]=3;
    memset(dp,0,sizeof(dp));
    dp[0]=1;
    for(int i=1; i<=3; i++)//依次添加每类货币
    {
        for(int j=i; j<=32768; j++)//枚举可使用第i类货币每一种可能的数和
        {
            dp[j]=dp[j]+dp[j-w[i]];// (累计前i-1类货币构成j-w[i]的方式数)
//dp[j]=dp[j]+dp[j-w[i]]的含义为:使用前i类货币时的货币组成可能可能的数(dp[j])=当使用前i-1类货币时的货币组成可能的数(dp[j])
//+选择使用一个i类货币+剩余钱数(j-w[i])组成的货币的数目(前i类)---这里有点背包的感觉,所以说他是背包的应用
} } while(scanf("%d",&n)!=EOF) { printf("%d\n",dp[n]); } return 0; }

 

子集和问题(应用--换零钱)

原文:http://www.cnblogs.com/zhangmingcheng/p/4360947.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!