编程语言
首页 > 编程语言> > 贪心算法——Java实现

贪心算法——Java实现

作者:互联网

概念:

贪心的意思在于在作出选择时,每次都要选择对自身最为有利的结果,保证自身利益的最大化。

题目:

小明手中有 1,5,10,50,100 五种面额的纸币,每种纸币对应张数分别为 5,2,2,3,5 张。若小明需要支付 456 元,则需要多少张纸币?

解题思路:

设小明每次选取一张面额为Xi的纸币,总共选择n张,则剩余待支付金额为R。

小明选择纸币进行支付的过程,可以划分为n个子问题:即每个子问题对应为:
在未超过456的前提下,在剩余的纸币中选择一张纸币。

在允许的条件下选择面额最大的纸币。

第一次选取100元,则R=456-100=356;

第二次选取100元,则R=356-100=256;

第三次选取100元,则R=256-100=156;

第四次选取100元,则R=156-100=56;

第五次选取50元,则R=56-50=6;

第六次选取5元,则R=6-5=1;

第七次选取1元,则R=1-1=0;

小明总共需要100元*4张+50元*1张+5元*1张+1元*1张。

 1 public class GreedyAlgorithmTest {
 2     private final int n = 5;
 3     private int[] count = {5,2,2,3,5};
 4     private int[] value = {1,5,10,50,100};
 5     
 6     @Test
 7     public void moneyNumber(){
 8         int money = 456;
 9         int num = 0;
10         for (int i = n-1; i >=0; i--) {
11             int min = Math.min(money / value[i], count[i]);
12             money = money - min*value[i];
13             num = num + min;
14         }
15         if (money>0){
16             num = -1;
17         }
18         System.out.println(num);
19     }
20 }

 

 

 

标签:Java,int,money,纸币,50,选取,算法,100,贪心
来源: https://www.cnblogs.com/iscanghai/p/14873626.html