首页 > 编程语言 > 详细

经典贪心算法实践

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

最简单的硬币问题:

题目描述:

有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 }

 

经典贪心算法实践

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

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!