zoukankan      html  css  js  c++  java
  • 120.货币系统(完全背包的方案数目)

    2054 货币系统

     

    USACO

     时间限制: 1 s
     空间限制: 128000 KB
     题目等级 : 黄金 Gold
    题目描述 Description

    母牛们不但创建了它们自己的政府而且选择了建立了自己的货币系统。由于它们特殊的思考方式,它们对货币的数值感到好奇。

    传统地,一个货币系统是由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),即在0 到2^63-1之间。

    输入描述 Input Description

    货币系统中货币的种类数目是 V (1<=V<=25)。要构造的数量钱是 N (1<= N<=10,000)。

    第一行: 二个整数,V 和 N 。

    第二行:可用的货币的面值 。

    输出描述 Output Description

    单独的一行包含那个可能的用这v种硬币凑足n单位货币的方案数。

    样例输入 Sample Input
    
    3 10
    1 2 5
    
    样例输出 Sample Output

    10

    数据范围及提示 Data Size & Hint

    见描述

    代码:

    #include< cstdio >

    #include< iostream >

    using namespace std;

    long long  f[10001],v,a[26],n;

    int main()

    {

    scanf("%d%d",&v,&n);

    for(int i=1;i<=v;++i)

    scanf("%d",&a[i]);

    f[0]=1;

    for(int i=1;i<=v;++i)

          for(int j=a[i];j<=n;++j)//除了转移方程外,其余和完全背包相同 

          f[j]+=f[j-a[i]];//f[]储存钱数为j的方案数目,因为f[0]=1,所以只有正好装满时,才有方案, 

    cout<<f[n]<<endl;//注意是长整形 

    return 0;

    }

  • 相关阅读:
    top指令
    Trie
    最大公约数
    angular2 获取到的数据无法实时更新的问题
    npm install 的时候出现 write access 导致不能成功安装的问题
    angular 的 @Input、@Output 的一个用法
    windows 安装 apache 服务以及添加 php 解析
    php 性能优化之opcache
    intellij 插件结构(文件结构以及概念层面上的结构)
    jetBrains 插件开发第一课-- 在主菜单栏新增一个菜单
  • 原文地址:https://www.cnblogs.com/c1299401227/p/5370694.html
Copyright © 2011-2022 走看看