码迷,mamicode.com
首页 > 编程语言 > 详细

经典贪心算法实践

时间:2017-09-08 00:11:23      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:include   iostream   using   硬币   clu   div   需要   描述   算法   

最简单的硬币问题:

题目描述:

有1,5,10,50,100,500的硬币各C1,C5,C10,C50,C100,C500枚,现在要用这些硬币来支付A元,最少需要多少枚硬币。

解题思路:

贪心算法,竟可能多的使用面值最大的硬币的这一贪心的策略来切了。

 1 #include <iostream>
 2 using namespace std;
 3 const int V[6]={1,5,10,50,100,500};
 4 int C[6]={3,2,1,3,0,2};
 5 int A=620;
 6 void solve(){
 7     int ans=0;
 8     for(int i=5;i>=0;i--)
 9     {
10         int t=min(A/V[i],C[i]);
11         A-=t*V[i];
12         ans+=t;
13     }
14     cout<<ans<<endl;
15 }
16 int main() {
17     solve();
18     return 0;
19 }

 

经典贪心算法实践

标签:include   iostream   using   硬币   clu   div   需要   描述   算法   

原文地址:http://www.cnblogs.com/guohaoyu110/p/6763267.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!