《算法笔记》11.7小节——动态规划专题->背包问题 问题 C: 货币系统

题目描述

母牛们不但创建了他们自己的政府而且选择了建立了自己的货币系统。

In their own rebellious way,,他们对货币的数值感到好奇。

传统地,一个货币系统是由1,5,10,20 或 25,50, 和 100的单位面值组成的。

母牛想知道有多少种不同的方法来用货币系统中的货币来构造一个确定的数值。

举例来说, 使用一个货币系统 {1,2,5,10,...}产生 18单位面值的一些可能的方法是:18x1, 9x2, 8x2+2x1, 3x5+2+1,等等其它。

写一个程序来计算有多少种方法用给定的货币系统来构造一定数量的面值。

保证总数将会适合long long (C/C++) 和 Int64 (Free Pascal)。

输入

输入包含多组测试数据

货币系统中货币的种类数目是 V 。 (1<= V<=25)

要构造的数量钱是 N 。 (1<= N<=10,000)

|-------------|------------------------------|
| 第 1 行: | 二整数, V 和 N |
| 第 2 ..V+1行: | 可用的货币 V 个整数 (每行一个 每行没有其它的数)。 |

输出

单独的一行包含那个可能的构造的方案数。

样例输入
复制代码
3 10
1 2 5
样例输出
复制代码
10

分析:由于没有限制货币可以取的数量,可知是完全背包问题。

cpp 复制代码
#include<algorithm>
#include <iostream>
#include  <cstdlib>
#include  <cstring>
#include   <string>
#include   <vector>
#include   <cstdio>
#include    <queue>
#include    <stack>
#include    <ctime>
#include    <cmath>
#include      <map>
#include      <set>
#define INF 0x3fffffff
#define db1(x) cout<<#x<<"="<<(x)<<endl
#define db2(x,y) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<endl
#define db3(x,y,z) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<", "<<#z<<"="<<(z)<<endl
#define db4(x,y,z,r) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<", "<<#z<<"="<<(z)<<", "<<#r<<"="<<(r)<<endl
#define db5(x,y,z,r,w) cout<<#x<<"="<<(x)<<", "<<#y<<"="<<(y)<<", "<<#z<<"="<<(z)<<", "<<#r<<"="<<(r)<<", "<<#w<<"="<<(w)<<endl
using namespace std;
 
int main(void)
{
    #ifdef test
    freopen("in.txt","r",stdin);
//    freopen("out.txt","w",stdout);
    clock_t start=clock();
    #endif //test
 
 
    int v,n;
    while(~scanf("%d%d",&v,&n))
    {
        int value[v+5]={0};
        long long dp[n+5]={1};
        for(int i=1;i<=v;++i)
            scanf("%d",&value[i]);
        for(int i=1;i<=v;++i)
        {
            for(int j=value[i];j<=n;++j)
            {
                dp[j]+=dp[j-value[i]];
            }
        }
        printf("%lld\n",dp[n]);
    }
 
 
    #ifdef test
    clockid_t end=clock();
    double endtime=(double)(end-start)/CLOCKS_PER_SEC;
    printf("\n\n\n\n\n");
    cout<<"Total time:"<<endtime<<"s"<<endl;        //s为单位
    cout<<"Total time:"<<endtime*1000<<"ms"<<endl;    //ms为单位
    #endif //test
    return 0;
}
相关推荐
-森屿安年-6 天前
63. 不同路径 II
c++·算法·动态规划
林森lsjs7 天前
斐波那契数列的 N 种解法:从递归到动态规划的优化之路【算法思考】
算法·动态规划
workflower7 天前
互联网与大数据环境下制造服务模式
人工智能·自然语言处理·数据挖掘·自动驾驶·动态规划·制造
2601_961845157 天前
花生十三网课网盘|百度网盘|下载
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
拂拉氏8 天前
【知识讲解-题目讲解】算法系列之动态规划入门(下)
算法·leetcode·动态规划
2601_961845158 天前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
workflower8 天前
使用大语言模型处理用户需求
大数据·人工智能·设计模式·重构·动态规划
青山木8 天前
Hot 100 --- 滑动窗口最大值
java·数据结构·算法·leetcode·动态规划
xhtdj9 天前
智源大会圆桌大模型没有终局具身智能可能是中国的 AlphaGo 时刻
人工智能·clickhouse·安全·动态规划
2301_764441339 天前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互