力扣每日一题 2024/3/24 零钱兑换

题目描述

用例说明

思路讲解

动态规划五步法

第一步确定dp数组的含义:dp[i]为凑到金额为i所用最少的硬币数量

第二步确定动态规划方程:凑足金额为j-coins[i]所需最少的硬币个数为dp[j-coins[i]],那凑足金额为j所用的最少硬币数为dp[j-coins[i]]+1

第三步初始化:凑足金额为0所需硬币数为0,即dp[0]=0

此外dp数组内其他值也需初始化为最大值,否则在遍历coins数组计算金额的时候容易被覆盖

第四步遍历顺序:外层遍历物品,内层遍历背包容量

第五步推导得出dp[amount]

代码

java 复制代码
class Solution {
    public int coinChange(int[] coins, int amount) {
      int max=Integer.MAX_VALUE;
      int[] dp=new int[amount+1];
      for(int i=0;i<dp.length;i++){
        dp[i]=max;
      }
      dp[0]=0;
      for(int i=0;i<coins.length;i++){
        for(int j=coins[i];j<=amount;j++){
            if(dp[j-coins[i]]!=max){
                dp[j]=Math.min(dp[j],dp[j-coins[i]]+1);
            }
        }
      }
      return dp[amount]==max?-1:dp[amount];
    }
}

复杂度

时间复杂度O(n*amount)

空间复杂度O(amount)

相关推荐
m0_748248026 分钟前
《详解 C++ Date 类的设计与实现:从运算符重载到功能测试》
java·开发语言·c++·算法
天选之女wow8 分钟前
【代码随想录算法训练营——Day61】图论——97.小明逛公园、127.骑士的攻击
算法·图论
aloha_78914 分钟前
测试开发工程师面经准备(sxf)
java·python·leetcode·压力测试
im_AMBER33 分钟前
Leetcode 47
数据结构·c++·笔记·学习·算法·leetcode
kyle~43 分钟前
算法数学---差分数组(Difference Array)
java·开发语言·算法
橘颂TA1 小时前
机器人+工业领域=?
算法·机器人
小O的算法实验室2 小时前
2025年TRE SCI1区TOP,随机环境下无人机应急医疗接送与配送的先进混合方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小白程序员成长日记2 小时前
2025.11.06 力扣每日一题
算法·leetcode
暴风鱼划水3 小时前
算法题(Python)数组篇 | 4.长度最小的子数组
python·算法·力扣
gugugu.3 小时前
算法:二分算法类型题目总结---(含二分模版)
算法