首页 > 代码库 > 【bzoj1708】[USACO2007 Oct]Money奶牛的硬币
【bzoj1708】[USACO2007 Oct]Money奶牛的硬币
题目描述
在创立了她们自己的政权之后,奶牛们决定推广新的货币系统。在强烈的叛逆心理的驱使下,她们准备使用奇怪的面值。在传统的货币系统中,硬币的面值通常是1,5,10,20或25,50,以及100单位的货币,有时为了更方便地交易,会发行面值为2单位的硬币。 奶牛们想知道,对于一个给定的货币系统,如果需要正好凑出一定数量的钱,会有多少种不同的方法。比如说,你手上有无限多个面值为{1,2,5,10,...}的硬币,并且打算凑出18单位货币,那么你有多种方法来达到你的目的:18*1,9*2,8*2+2*1,3*5+2+1,以及其他的未列出的若干方案。 请你写一个程序,帮奶牛们计算一下,如果想用有V (1 <= V <= 25)种面值的硬币,凑出总价值为N(1 <= N <= 10,000)的一堆钱,一共有多少种不同的方法。答案保证不会超出C/C++中的‘long long‘,Pascal中的‘Int64‘,或是Java中的‘long‘的范围。
输入
* 第1行: 2个用空格隔开的整数:V和N
* 第2..V+1行: 每行1个整数,表示1种硬币面值
输出
* 第1行: 输出1个正整数,表示用这V种面值的硬币,凑出N单位的货币的不同方法总数。
样例输入
3 10
1
2
5
样例输出
10
题解
完全背包水题,没啥要注意的
1 #include <cstdio> 2 long long f[10001]; 3 int main() 4 { 5 int v , n , i , t; 6 scanf("%d%d" , &v , &n); 7 f[0] = 1; 8 while(v -- ) 9 { 10 scanf("%d" , &t); 11 for(i = t ; i <= n ; i ++ ) 12 f[i] += f[i - t]; 13 } 14 printf("%lld\n" , f[n]); 15 return 0; 16 }
【bzoj1708】[USACO2007 Oct]Money奶牛的硬币
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。