51nod 1101 换零钱
2016-06-27 11:55
239 查看
题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1101
题目:
N元钱换为零钱,有多少不同的换法?币值包括1 2 5分,1 2 5角,1 2 5 10 20 50 100元。
例如:5分钱换为零钱,有以下4种换法:
1、5个1分
2、1个2分3个1分
3、2个2分1个1分
4、1个5分
(由于结果可能会很大,输出Mod 10^9 + 7的结果)
Input
Output
Input示例
Output示例
可以用完全背包来做。
#include <iostream>
#include<bits/stdc++.h>
#define MOD 1000000007
using namespace std;
int w[13]={1,2,5,10,20,50,100,200,500,1000,2000,5000,10000};
int d[110000];
int main()
{
int n;
scanf("%d",&n);
d[0]=1;
for(int i=0;i<13;i++)
for(int j=w[i];j<=n;j++)
d[j]=(d[j]+d[j-w[i]])%MOD;
cout<<d
<<endl;
}
题目:
N元钱换为零钱,有多少不同的换法?币值包括1 2 5分,1 2 5角,1 2 5 10 20 50 100元。
例如:5分钱换为零钱,有以下4种换法:
1、5个1分
2、1个2分3个1分
3、2个2分1个1分
4、1个5分
(由于结果可能会很大,输出Mod 10^9 + 7的结果)
Input
输入1个数N,N = 100表示1元钱。(1 <= N <= 100000)
Output
输出Mod 10^9 + 7的结果
Input示例
5
Output示例
4
可以用完全背包来做。
#include <iostream>
#include<bits/stdc++.h>
#define MOD 1000000007
using namespace std;
int w[13]={1,2,5,10,20,50,100,200,500,1000,2000,5000,10000};
int d[110000];
int main()
{
int n;
scanf("%d",&n);
d[0]=1;
for(int i=0;i<13;i++)
for(int j=w[i];j<=n;j++)
d[j]=(d[j]+d[j-w[i]])%MOD;
cout<<d
<<endl;
}
相关文章推荐
- JS正则表达式验证数字代码
- 通过Application存取公共数据比如登录信息等..
- Mybaits Generator自动生成代码
- 由MTK平台 mtkfb 设备注册疑问引发的知识延伸--ARM Device Tree
- list packages
- PagerSlidingTabStrip实现横划
- 魅族 MX4,MX4 Pro,MX5 android studio无法识别问题
- 误删的恢复: DBA的噩梦
- 精通iOS开发--第15章 Grand Central Dispatch和后台处理之Block与Self的循环引用
- JSP 自定义标签
- [dfs序 树状数组] BZOJ 1103 [POI2007]大都市meg
- 寻找一个字符串中连续出现次数最多的子串(面试宝典14.5节面试题1)
- 32位和64位操作系统
- Javascript创建对象的七种模式(你必须掌握!)
- 数据预处理系列:(十三)用字典学习分解法分类
- C#中的委托之操作符(基础二)
- logiscope 应用度量元 翻译和解释
- Android自动识别<a>标签的自定义TextView(可自定义点击事件)
- undo/delete a commit on git
- centos6: mysql+nginx+php