我用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;
    }
}

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

相关推荐
go不是csgo8 小时前
从0到1理解Go熔断器:sony/gobreaker 源码剖析 + 仿TikTok Feed 项目实战
开发语言·后端·golang
SimonKing8 小时前
线程池面试被问到怕?看完这篇让他当场沉默
java·后端·程序员
JAVA面经实录9178 小时前
NoSQL 非关系型数据库【简洁版】
java·数据库·nosql
小蒋学算法8 小时前
算法-计算右侧小于当前元素的个数-分治&归并思想
java·数据结构·算法
阿狸猿8 小时前
论企业应用系统的分层架构风格
java·开发语言·架构
JAVA9658 小时前
JAVA面试-并发篇 07-CAS底层原理是什么有什么缺陷如何解决
java·开发语言·面试
San813_LDD8 小时前
[QT]Qt对象树笔记:父子关系与内存管理
开发语言·qt
gaohe26AIliuzeyu8 小时前
Java接口
java·开发语言
满怀冰雪9 小时前
第05篇-滑动窗口算法-一套模板解决子串与子数组问题
java·算法
码云骑士9 小时前
【3.1Java基础】Java运算符常见错误排查:10个高频编译运行错误一网打尽
java·开发语言