博客
关于我
LeetCode 动态规划 coin change
阅读量:364 次
发布时间:2019-03-04

本文共 1292 字,大约阅读时间需要 4 分钟。

为了找到凑成给定总金额所需的最少硬币个数,我们可以使用动态规划的方法。以下是详细的解决方案:

动态规划方法

  • 初始化数组:创建一个大小为 amount + 1 的数组 f,其中 f[i] 表示凑成金额 i 所需的最少硬币数。初始化所有元素为 Integer.MAX_VALUE,除了 f[0] 设为 0,因为凑成0元不需要任何硬币。

  • 遍历金额:从1到 amount 逐一处理每个金额 i

  • 遍历硬币面额:对于每个金额 i,遍历所有硬币的面额 coins[j]。如果 i 大于或等于 coins[j],则更新 f[i]f[i - coins[j]] + 1 和当前 f[i] 中的较小值。

  • 检查结果:最后,检查 f[amount] 是否仍然是 Integer.MAX_VALUE。如果是,说明无法凑成总金额,返回-1;否则,返回 f[amount]

  • 代码实现

    public class CoinChange {    public int minCoins(int[] coins, int amount) {        int[] f = new int[amount + 1];        for (int i = 0; i <= amount; i++) {            f[i] = Integer.MAX_VALUE;        }        f[0] = 0;                for (int i = 1; i <= amount; i++) {            for (int j = 0; j < coins.length; j++) {                if (i >= coins[j]) {                    if (f[i - coins[j]] + 1 < f[i]) {                        f[i] = f[i - coins[j]] + 1;                    }                }            }        }                if (f[amount] == Integer.MAX_VALUE) {            return -1;        } else {            return f[amount];        }    }}

    代码解释

  • 初始化数组:数组 f 初始化为 Integer.MAX_VALUEf[0] 设为 0,表示凑成0元不需要硬币。

  • 遍历金额:外层循环从1到 amount,逐一处理每个金额。

  • 遍历硬币:内层循环遍历每个硬币的面额,检查当前硬币是否可以用于凑成当前金额。

  • 更新最少硬币数:如果当前硬币可用于凑成金额,更新 f[i] 为使用该硬币后的最少硬币数。

  • 返回结果:检查最终结果,返回-1表示无法凑成,否则返回所需硬币数。

  • 这种方法确保了每个金额的最优解,通过动态规划有效地分解问题,确保了最终结果的正确性。

    转载地址:http://gdyg.baihongyu.com/

    你可能感兴趣的文章
    OpenCV学习(13) 细化算法(1)(转)
    查看>>
    OpenCV学习笔记(27)KAZE 算法原理与源码分析(一)非线性扩散滤波
    查看>>
    OpenCV学堂 | CV开发者必须懂的9种距离度量方法,内含欧氏距离、切比雪夫距离等(建议收藏)
    查看>>
    OpenCV学堂 | OpenCV案例 | 基于轮廓分析对象提取
    查看>>
    OpenCV学堂 | YOLOv8实战 | 荧光显微镜细胞图像检测
    查看>>
    OpenCV学堂 | 汇总 | 深度学习图像去模糊技术与模型
    查看>>
    OpenCV官方文档 理解k - means聚类
    查看>>
    OpenCV探索
    查看>>
    OpenCV环境搭建(一)
    查看>>
    openCV目标识别 目标跟踪 YOLO5深度学习 Python 计算机视觉 计算机毕业设计 源码下载
    查看>>
    opencv笔记(1):图像缩放
    查看>>
    opencv笔记(二十四)——得到轮廓之后找到凸包convex hull
    查看>>
    OpenCV计算点到直线的距离 数学法
    查看>>
    Opencv识别图中人脸
    查看>>
    OpenCV读写avi、mpeg文件
    查看>>
    opencv面向对象设计初探
    查看>>
    OpenCV(1)读写图像
    查看>>
    OpenCV:不规则形状区域中每种颜色的像素数?
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    OpenDaylight融合OpenStack架构分析
    查看>>