BZOJ1708 [Usaco2007 Oct]Money奶牛的硬币
来源:互联网 发布:哈工大电力大数据 编辑:程序博客网 时间:2024/05/16 06:53
标记:背包DP
Description
在创立了她们自己的政权之后,奶牛们决定推广新的货币系统。在强烈的叛逆心理的驱使下,她们准备使用奇怪的面值。在传统的货币系统中,硬币的面值通常是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'的范围。
Input
* 第1行: 2个用空格隔开的整数:V和N
* 第2..V+1行: 每行1个整数,表示1种硬币面值
Output
* 第1行: 输出1个正整数,表示用这V种面值的硬币,凑出N单位的货币的不同方法总数。
Sample Input
3 10
1
2
5
Sample Output
10
Code
#include<bits/stdc++.h>#define LL long longusing namespace std;int v,n,a[26];LL f[10001];int main(){scanf("%d%d",&n,&v);for(int i=1;i<=n;i++)scanf("%d",&a[i]);f[0]=1;for(int i=1;i<=n;i++) for(int j=a[i];j<=v;j++) f[j]+=f[j-a[i]]; printf("%lld",f[v]);return 0;}
阅读全文
0 0
- bzoj1708[Usaco2007 Oct]Money奶牛的硬币
- BZOJ1708 [Usaco2007 Oct]Money奶牛的硬币
- 【BZOJ1708】[Usaco2007 Oct]Money奶牛的硬币【完全背包】
- bzoj1708 [Usaco2007 Oct]Money奶牛的硬币(完全背包)
- 1708: [Usaco2007 Oct]Money奶牛的硬币
- BZOJ 1708: [Usaco2007 Oct]Money奶牛的硬币
- BZOJ 1708: [Usaco2007 Oct]Money奶牛的硬币
- 【bzoj 1708】[Usaco2007 Oct]Money奶牛的硬币
- BZOJ 1690: [Usaco2007 Dec]奶牛的旅行
- bzoj1690 [Usaco2007 Dec]奶牛的旅行
- 【BZOJ 1690】 [Usaco2007 Dec]奶牛的旅行
- 1690: [Usaco2007 Dec]奶牛的旅行
- bzoj 1690: [Usaco2007 Dec]奶牛的旅行
- bzoj1690/poj3621[Usaco2007 Dec]奶牛的旅行
- 1690: [Usaco2007 Dec]奶牛的旅行
- 【bzoj1690】[Usaco2007 Dec]奶牛的旅行
- bzoj1708
- bzoj1669 [Usaco2006 Oct]Hungry Cows饥饿的奶牛
- 练习go基础语法
- HMM之维特比算法
- torch.nn.Parameter(nn/parameter.py)
- CSS :after伪类实现圆形蒙板动画,翻转
- 用com.google.zxing创建二维码
- BZOJ1708 [Usaco2007 Oct]Money奶牛的硬币
- 比较总结线性表的几种主要存储结果
- 设计模式21-访问者模式
- 使用idea根据数据库表生成java model类,基于hibernate
- Linux安装supervisor
- 思维导图带你走进春的世界
- 蓝牙4.0协议栈基础
- 1044. Lucky Tickets. Easy!
- 【Android】沉浸式状态栏设置