java代码实现贪心算法深入简出

贪心算法

贪心算法是一种基于贪心思想的算法,它在每一步选择中都采取当前状态下最优的选择,从而希望最终得到全局最优解。

下面是使用Java代码实现贪心算法的例子:

假设我们有一堆硬币,它们的面值分别为1元、5元、10元、50元、100元,现在要用尽量少的硬币凑出36元。

1. 首先,我们需要定义一个数组,用于存储硬币的面值:

int[] coins = {1, 5, 10, 50, 100}; 

2. 接着,我们定义一个变量sum,用于记录当前已经凑出的金额。初始化sum为0:

int sum = 0; 

3. 我们还需要定义一个变量count,用于记录已经使用的硬币数量。初始化count为0:

int count = 0; 

4. 接下来,我们可以使用一个while循环来不断地选取当前状态下面值最大的硬币,并将它加入到已选硬币集合中:

while (sum < 36) {
    for (int i = coins.length - 1; i >= 0; i--) {
        if (sum + coins[i] <= 36) {
            sum += coins[i];
            count++;
            break;
        }
    }
}

5. 最后,我们输出所选硬币的数量:

System.out.println("使用硬币数量为:" + count);

完整代码如下:

public static void main(String[] args) {
    int[] coins = {1, 5, 10, 50, 100};
    int sum = 0;
    int count = 0;
    while (sum < 36) {
        for (int i = coins.length - 1; i >= 0; i--) {
            if (sum + coins[i] <= 36) {
                sum += coins[i];
                count++;
                break;
            }
        }
    }
    System.out.println("使用硬币数量为:" + count);
}

以上代码实现了一个简单的贪心算法,它通过不断地选取面值最大的硬币来凑出指定金额,以达到尽可能少地使用硬币的目的。在实际应用中,我们可以根据具体情况设计更加复杂的贪心算法,以求得更好的效果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我的头发哪去了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值