题目: 有1, 5, 10, 50, 100, 500元硬币各若干枚, 现在要用这些硬币来支付A元, 最少需要多少枚硬币?
假定本题至少存在一种支付方案.
使用贪心算法, 优先选用最大的硬币, 并不断的调整硬币的数量.
代码:
/* * main.cpp * * Created on: 2014.7.17 * Author: spike */ /*eclipse cdt, gcc 4.8.1*/ #include <stdio.h> #include <limits.h> #include <utility> #include <queue> using namespace std; class Program { const int V[6] = {1, 5, 10, 50, 100, 500}; int C[6] = {3, 2, 1, 3, 0, 2}; int A = 620; public: void solve() { int ans = 0; for (int i=5; i>=0; i--) { int t = min(A/V[i], C[i]); A -= t*V[i]; ans += t; } printf("result = %d\n", ans); } }; int main(void) { Program P; P.solve(); return 0; }
输出:
result = 6
本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/Programming/sjjg/
作者:csdn博客 Mystra
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索算法
, int
, 支付
, include
, 代码
, 贪心算法
, 算法 编程
, 贪心算法的题目
, program
编程算法
贪心算法硬币找钱问题、最少硬币问题算法、假硬币问题算法、贪心算法背包问题代码、旅行商问题算法代码,以便于您获取更多的相关知识。
时间: 2024-09-19 03:50:35