• 洛谷P1474 [USACO 2.3]货币系统 Money Systems [2017年4月计划 动态规划04]


    P1474 货币系统 Money Systems

    题目描述

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

    传统地,一个货币系统是由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之间。

    输入输出格式

    输入格式:

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

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

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

    输出格式:

    输出格式:

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

    输入输出样例

    输入样例#1:
    3 10
    1 2 5
    
    输出样例#1:
    10
    

    说明

    翻译来自NOCOW

    USACO 2.3

    与砝码称重相似:http://www.cnblogs.com/huibixiaoxing/p/6723080.html

    完全背包计数。注意long long

    #include <iostream>
    #include <cstdio>
    #include <cstdlib>
    #include <cstring>
    #include <algorithm>
    
    inline int read()
    {
    	int x = 0;char ch = getchar();char c = ch;
    	while(ch >'9' || ch < '0')c = ch,ch = getchar();
    	while(ch <= '9' && ch >= '0')x = x * 10 + ch - '0',ch = getchar();
    	if(c == '-')return -1 * x;
    	return x;
    }
    
    
    const int INF = 999999999;
    const int MAXN = 10000 + 10;
    const int MAXV = 25 + 5;
    
    long long w[MAXV];
    long long f[MAXN];
    long long v,n;
    
    
    int main()
    {
    	v = read();n = read();
    	for(int i = 1;i <= v;i ++){
    		w[i] = read();
    	}
    	f[0] = 1;
    	for(long long i = 1;i <= v;i ++){
    		for(long long j = w[i];j <=n;j ++){
    			f[j] += f[j - w[i]];
    		}
    	}
    	std::cout<<f[n];
    	return 0;
    }
    
  • 相关阅读:
    log4j 配置详解
    log4j2单独的配置与使用&log4j2+slf4j的结合的配置与使用
    jdk时区相差8小时
    javax.servlet.ServletException: java.lang.NoClassDefFoundError: javax/el/ELResolver错误解决办法
    SqlServer 统计用户量实例(按年,月,日分组)
    sqlserver with as 双向递归
    eclipse启动无响应,停留在Loading workbench状态
    JS制作闪动的图片
    查询数据库中表名和扩展属性
    sql 查询除某字段的其他字段的记录
  • 原文地址:https://www.cnblogs.com/huibixiaoxing/p/6728509.html
Copyright © 2020-2023  润新知