力扣每日一题 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)

相关推荐
Code-keys2 小时前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码
无忧智库2 小时前
低空经济新基建:构建低空飞行大数据中心与行业应用算法工厂的全景式蓝图(WORD)
算法
闻缺陷则喜何志丹3 小时前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
小章UPUP4 小时前
2026年第十六届MathorCup数学应用挑战赛D题国奖思路
算法
hssfscv4 小时前
软件设计师下午试题四——C语言(N皇后问题、分治、动态规划)
c语言·算法·动态规划
lolo大魔王4 小时前
Go语言的反射机制
开发语言·后端·算法·golang
白羊by4 小时前
Softmax 激活函数详解:从数学原理到应用场景
网络·人工智能·深度学习·算法·损失函数
故事和你914 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
chipsense5 小时前
霍尔电流传感器选型方法论再升级:从800V平台到TMR竞争的全场景决策树
算法·决策树·机器学习·闭环霍尔·tmr传感
CoderYanger5 小时前
14届蓝桥杯省赛Java A 组Q1~Q3
java·开发语言·线性代数·算法·职场和发展·蓝桥杯