我用Java语言写了一个贪心算法小案例

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是最好或最优的算法。贪心算法在有最优子结构的问题中尤为有效。最优子结构的意思是局部最优解能决定全局最优解。

下面是一个使用Java实现的贪心算法示例,该算法解决了找零问题。给定一组硬币面值和一个总金额,我们需要找到最少的硬币数量来凑成这个总金额。

java 复制代码
import java.util.Arrays;

public class GreedyAlgorithm {
    public static void main(String[] args) {
        int[] coins = {1, 2, 5, 10, 20, 50, 100};
        int amount = 93;
        System.out.println("Minimum number of coins required: " + findMinCoins(coins, amount));
    }

    public static int findMinCoins(int[] coins, int amount) {
        Arrays.sort(coins); // 对硬币面值进行排序
        int count = 0;
        for (int i = coins.length - 1; i >= 0; i--) {
            while (amount >= coins[i]) {
                amount -= coins[i];
                count++;
            }
        }
        return count;
    }
}

在这个例子中,我们首先对硬币面值进行排序,然后从最大的硬币面值开始,尽可能多地使用该硬币,直到无法继续使用为止。然后我们继续尝试下一个较小的硬币面值,以此类推,直到凑齐总金额。最后返回使用的硬币数量。

相关推荐
xuzhiqiang072415 小时前
Java进阶之路,Java程序员职业发展规划
java·开发语言
时艰.15 小时前
订单系统历史数据归档方案
java
MediaTea15 小时前
Python:生成器表达式详解
开发语言·python
一只叫煤球的猫17 小时前
ThreadForge v1.1.0 发布:让 Java 并发更接近 Go 的开发体验
java·后端·性能优化
overmind17 小时前
oeasy Python 115 列表弹栈用pop删除指定索引
开发语言·python
014.17 小时前
2025最新jenkins保姆级教程!!!
java·运维·spring boot·spring·jenkins
浣熊88817 小时前
天机学堂虚拟机静态ip无法使用(重启后ip:192.168.150.101无法使用连接Mobaxterm数据库等等,或者无法使用修改之后的Hosts域名去访问nacos,jenkins)
java·微服务·虚拟机·天机学堂·重启之后静态ip用不了
心 -18 小时前
java八股文IOC
java
Never_Satisfied18 小时前
在c#中,使用windows自带功能将文件夹打包为ZIP
开发语言·windows·c#
hnxaoli18 小时前
win10程序(十六)通达信参数清洗器
开发语言·python·小程序·股票·炒股