贪心算法解决找零钱问题

贪心算法是算法设计中的三大核心思想(贪心、动态规划、回溯)之一,核心逻辑是 "每次都做当前看起来最优的选择,最终期望得到全局最优解"。它不像回溯法那样暴力搜索所有可能,也不像动态规划那样依赖子问题的重叠性,而是通过 "局部最优决策" 快速逼近全局最优,效率通常很高(大多是 O (n) 或 O (nlogn))。

下面从 核心思想、适用条件、经典案例、与其他算法对比 四个维度,帮你彻底掌握贪心算法。

一、什么是贪心算法?

贪心算法的本质的是:不纠结于未来,只关注当下的 "最优解",并且坚信 "把每一步的局部最优拼起来,就是全局最优"。

生活中的贪心例子:
  1. 找零问题:用最少的硬币凑够指定金额(比如用 1、5、10、20 元硬币找零 37 元,最优策略是先拿 20 元,再拿 10 元,再拿 5 元,最后拿 2 个 1 元,共 4 枚硬币)------ 每次选面值最大的硬币,就是 "局部最优"。
  2. 选课问题:想选最多的课程,且课程时间不冲突 ------ 每次选 "结束时间最早" 的课程,这样剩下的时间最多,能选更多课。
  3. 背包问题(部分背包):背包容量有限,物品可分割,想装最大价值的物品 ------ 每次选 "单位重量价值最高" 的物品(比如黄金比石头单位价值高,先装黄金)。
贪心算法的核心要素:
  1. 贪心选择性质:局部最优选择能导出全局最优解(这是贪心算法成立的关键,需要证明或验证);
  2. 最优子结构:全局最优解包含子问题的最优解(和动态规划的最优子结构一致)。
贪心算法的通用步骤:
  1. 问题拆解:将原问题分解为多个子问题(每个子问题对应一步决策);
  2. 确定贪心策略:找到每一步的 "局部最优" 选择标准(比如找零选最大面值,活动选择选最早结束);
  3. 验证可行性:确认该贪心策略能导出全局最优解(这是最关键的一步,很多问题看似能用贪心,实则不行);
  4. 代码实现:按贪心策略逐步执行,累积结果。
贪心策略解决硬币找零问题步骤
  1. 将硬币按面值降序排序(优先选大面值);
  2. 遍历硬币,对当前面值,尽可能多拿(用除法计算最大可拿数量);
  3. 减去已拿硬币的总金额,更新剩余金额;
  4. 剩余金额为 0 时,返回硬币总数
java 复制代码
    public static Map<Integer, Integer> minCoins(int[] coins, int amount) {
        Arrays.sort(coins);
        Map<Integer, Integer> result = new TreeMap<>();
        for (int i = coins.length - 1; i >= 0; i--) {
            if(amount >= coins[i]) {
                result.put(coins[i], amount/coins[i]);
                amount = amount % coins[i];
            }
        }
        return result;
    }

   public static void main(String[] args) {
        int[] coins = {1, 2, 5, 10, 20, 50};
        int amount = 101;
        System.out.println("最少硬币数:" + JSONUtil.toJsonStr(minCoins(coins, amount)));
    }
相关推荐
小羊在睡觉5 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary5 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记5 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466855 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
_日拱一卒5 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM6 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro7 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort7 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域7 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS8 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法