博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[BZOJ1708][Usaco2007 Oct]Money奶牛的硬币
阅读量:5146 次
发布时间:2019-06-13

本文共 1375 字,大约阅读时间需要 4 分钟。

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

Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 802  Solved: 543 [][][]

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
 
背包
#include 
#include
char buf[5000000], *ptr = buf - 1;inline int readint(){ int n = 0; char ch = *++ptr; while(ch < '0' || ch > '9') ch = *++ptr; while(ch <= '9' && ch >= '0'){ n = (n << 1) + (n << 3) + ch - '0'; ch = *++ptr; } return n;}typedef long long ll;ll dp[100010] = {
0}; int main(){ fread(buf, sizeof(char), sizeof(buf), stdin); int V, N; V = readint(); N = readint(); dp[0] = 1; for(int t, i = 1; i <= V; i++){ t = readint(); for(int j = t; j <= N; j++) dp[j] += dp[j - t]; } printf("%lld\n", dp[N]); return 0;}

 

转载于:https://www.cnblogs.com/ruoruoruo/p/7506483.html

你可能感兴趣的文章
html form action
查看>>
记一次Oracle Clusterware成功安装后的故障处理
查看>>
工作笔记-javascript-网络层封装
查看>>
Laravel Relationship Events
查看>>
求一个有一千个元素的整数数组的最大子数组的和
查看>>
普天C++笔试题
查看>>
Android Studio如何引用外部Library工程
查看>>
HTML5 Canvas 用requestAnimation取代setInterval
查看>>
软件需求模式阅读笔记五
查看>>
《AndroidStudio有用指南》反馈问题和建议
查看>>
WCF探索之旅(三)——IIS公布WCF服务
查看>>
update与upgrade
查看>>
轻量级的绘制图表js库--Morris.js
查看>>
POS tagging的解釋
查看>>
TI(德州仪器) TMS320C674x逆向分析之二
查看>>
WCF学习
查看>>
获取发送请求的ip
查看>>
Activity详解
查看>>
CCF201409-2 画图
查看>>
文件基本操作
查看>>