贪心:钱币找零问题(C++)
贪心是一种算法范例,它一点一点地构建解决方案,总是选择下一个提供最明显和最直接好处的部分。因此,选择局部最优也会导致全局解的问题最适合贪心问题。
例如,考虑分数背包问题。局部最优策略是选择权重比最大的项。这个策略也导致了全局最优解。
假设1元、2元、5元、10元、20元、50元、100元的纸币分别有a,b,c,d,e,f,g张。现在要用这些钱来支付m元,至少要用多少张纸币?用贪心算法的思想,每一次选择最大面值的钱币。
#include <iostream>
#include <vector>
#include <algorithm> using namespace std; vector<int> Num{ ,,,,,, }, Value{ ,,,,,, }; int BagsQues(int money) {
int sum = ;
for (int i = Value.size() - ; i >= ; --i) {
int N = min(money / Value[i], Num[i]);
money = money - N * Value[i];
sum += N;
if (money == )
return sum;
} return -;
} int main()
{
int money;
cin >> money;
int m = BagsQues(money);
cout << m << endl; system("PAUSE");
return ;
}
求出每张面额,用了多少张:
#include <iostream>
#include <vector>
#include <tuple>
#include <algorithm> using namespace std; vector<int> Num{ ,,,,,, }, Value{ ,,,,,, }; vector<tuple<int, int> > BagsQues(int money) {
int sum = ;
vector<tuple<int, int> > ch;
for (int i = Value.size() - ; i >= ; --i) {
int N = min(money / Value[i], Num[i]);
money = money - N * Value[i];
sum += N;
if (N != ) {
ch.push_back({ Value[i], N });
}
if(money == )
return ch;
}
ch.clear();
ch.push_back({ -, - });
return ch;
} int main()
{
int money;
cin >> money;
vector<tuple<int, int> > m = BagsQues(money);
for (int i = ; i < m.size(); ++i) {
cout << get<>(m[i]) << ":" << get<>(m[i]) << endl;
} system("PAUSE");
return ;
}
贪心:钱币找零问题(C++)的更多相关文章
- js贪心算法---钱币找零问题
		
function MinCoinChange(coins){ var coins = coins.sort(function(a,b){ return b - a; }); this.makeChan ...
 - LeetCode 860. 柠檬水找零 (贪心)
		
在柠檬水摊上,每一杯柠檬水的售价为 5 美元. 顾客排队购买你的产品,(按账单 bills 支付的顺序)一次购买一杯. 每位顾客只买一杯柠檬水,然后向你付 5 美元.10 美元或 20 美元.你必须给 ...
 - codevs 3961 硬币找零【完全背包DP/记忆化搜索】
		
题目描述 Description 在现实生活中,我们经常遇到硬币找零的问题,例如,在发工资时,财务人员就需要计算最少的找零硬币数,以便他们能从银行拿回最少的硬币数,并保证能用这些硬币发工资. 我们应该 ...
 - 没有找零 状压dp
		
没有找零 状压dp 约翰到商场购物,他的钱包里有K(1 <= K <= 16)个硬币,面值的范围是1..100,000,000.约翰想按顺序买 N个物品(1 <= N <= 1 ...
 - NYOJ 995 硬币找零
		
硬币找零 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 在现实生活中,我们经常遇到硬币找零的问题,例如,在发工资时,财务人员就需要计算最少的找零硬币数,以便他们能从 ...
 - usaco 最少找零
		
Description 约翰在镇上买了 T 元钱的东西,正在研究如何付钱.假设有 N 种钞票,第 i 种钞票的面值为 Vi,约翰身上带着这样的钞票 Ci 张.商店老板罗伯是个土豪,所有种类的钞票都有无 ...
 - python基础----找零问题
		
给定要找回的总钱数和硬币的种类,求出找零所需最少的硬币数目. 例如: 总钱数63,硬币种类为25.21.10.5.1,求出最小硬币数 分析: 我们可以先假设只有一种硬币1, 假如总钱数为1,硬币数就为 ...
 - 【LeetCode】860. 柠檬水找零
		
860. 柠檬水找零 知识点:贪心 题目描述 在柠檬水摊上,每一杯柠檬水的售价为 5 美元. 顾客排队购买你的产品,(按账单 bills 支付的顺序)一次购买一杯. 每位顾客只买一杯柠檬水,然后向你付 ...
 - [LeetCode] Coin Change 硬币找零
		
You are given coins of different denominations and a total amount of money amount. Write a function ...
 
随机推荐
- com.fasterxml.jackson.databind.JavaType.isReferenceType
			
<dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-map ...
 - js 值传递,引用传递
			
参考:http://www.cnblogs.com/lcngu/p/5876273.html JS的基本类型,是按值传递的. 对象类型按共享传递的(call by sharing,也叫按对象传递.按对 ...
 - 【C# MVC】
			
http://www.cnblogs.com/powertoolsteam/p/MVC_three.html
 - iOS开发之蓝牙使用-建立连接的
			
1.大佬笔记 CSDN 2.代码 github
 - AB二进制
			
Description 若将一个正整数化为二进制数,在此二进制数中,我们将数字1的个数多于数字0的个数的这类二进制数称为A类数,否则就称其为B类数. 例如: (13)10=(1101)2 ...
 - JAVA环境的JAVA_HOME, PATH 和CLASS_PATH设置
			
Windows下JAVA用到的环境变量主要有3个,JAVA_HOME.CLASSPATH.PATH.下面逐个分析. 简单来讲, 1.path是os用 classpath java用 JAVA_HOME ...
 - Java性能优化之高性能JAVA代码的若干个习惯
			
创建对象: 1.避免在循环体中创建对象,循环前应该创建对象,避免浪费更多内存空间和增加GC负担 这种情况在我们的实际应用中经常遇到,而且我们很容易犯类似的错误,例如下面的代码: for (int i ...
 - linux下redis的安装与django-redis使用方法
			
Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set( ...
 - [转载]np.where()使用说明
			
转载自https://www.cnblogs.com/massquantity/p/8908859.html#4072620 numpy.where() 有两种用法: 1. np.where(cond ...
 - ubuntu下vnc部署安装
			
ubuntu下vnc部署安装,参考如下博客:https://www.cnblogs.com/xuliangxing/p/7642650.html https://jingyan.baidu.com/a ...