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

题目描述

用例说明

思路讲解

动态规划五步法

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

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

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

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

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

第五步推导得出dpamount

代码

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)

相关推荐
IronMurphy1 分钟前
【算法五十八】23. 合并 K 个升序链表
数据结构·算法·链表
思茂信息8 分钟前
CST软件基于液态金属开关的方向图可重构天线
服务器·算法·重构·cst·仿真软件·电磁仿真
月疯32 分钟前
PPG研究中暑的算法记录
算法
春日见1 小时前
vscode的AI编程插件推荐:
大数据·ide·vscode·算法·机器学习·编辑器·ai编程
blxr_1 小时前
力扣hot100路径总和Ⅲhttps://leetcode.cn/problems/path-sum-iii/
算法·leetcode·职场和发展
noipp1 小时前
【无标题】
c语言·数据结构·c++·算法
渡众机器人1 小时前
第八届全球校园人工智能算法精英大赛-算法应用赛-渡众机器人智能体对抗挑战赛规则
人工智能·算法·机器人·自动驾驶·自主导航·对抗赛
郝学胜-神的一滴2 小时前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
java·开发语言·数据结构·c++·python·算法
青山木2 小时前
Hot 100 --- 缺失的第一个正数
算法·leetcode·哈希算法
农民小飞侠2 小时前
[leetcode] 165. Compare Version Numbers
java·算法·leetcode