前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >1708: [Usaco2007 Oct]Money奶牛的硬币

1708: [Usaco2007 Oct]Money奶牛的硬币

作者头像
HansBug
发布2018-04-10 16:32:40
5220
发布2018-04-10 16:32:40
举报
文章被收录于专栏:HansBug's Lab

1708: [Usaco2007 Oct]Money奶牛的硬币

Time Limit: 5 Sec  Memory Limit: 64 MB

Submit: 544  Solved: 352

[Submit][Status]

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

题解:真心水题。。。就是无限背包问题,求种类数,基本方式不变(HansBug:逗比的我还是把内循环的b[i]写成了a[i],然后WAWAWAA。。。TT phile:我也是醉了)

代码语言:javascript
复制
 1 var
 2    i,j,k,m,n:longint;l:int64;
 3    a:array[0..20000] of int64;
 4    b:array[0..100] of longint;
 5 begin
 6      readln(m,n);
 7      for i:=1 to m do readln(b[i]);
 8      fillchar(a,sizeof(a),0);
 9      a[0]:=1;
10      for i:=1 to m do
11          for j:=b[i] to n do
12              a[j]:=a[j]+a[j-b[i]];
13      writeln(a[n]);
14 end.
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015-01-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1708: [Usaco2007 Oct]Money奶牛的硬币
  • Description
  • Input
  • Output
  • Sample Input
  • Sample Output
  • HINT
  • Source
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档