【bzoj 1708】[Usaco2007 Oct]Money奶牛的硬币

14 篇文章 0 订阅
12 篇文章 0 订阅

[Usaco2007 Oct]Money奶牛的硬币

Time Limit: 5 Sec Memory Limit: 64 MB
Submit: 745 Solved: 497
[Submit][Status][Discuss]
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
HINT

Source

Gold
01背包 统计方案数

#include<iostream>
#include<cstdio>
using namespace std;
int v,n;
int a[26];long long f[10001];
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]];
   printf("%lld",f[n]);
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值