【算法四十四】322. 零钱兑换

322. 零钱兑换

动态规划

java 复制代码
class Solution {
    public int coinChange(int[] coins, int amount) {
        Arrays.sort(coins);
        //子问题:在前i个硬币中选择最少的个数满足amount
        //dp[amount] = Math.min(dp[amount],dp[amount-coins[i]])+1
        //自下而上
        int[] dp = new int[amount+1];
        //因为就算是金额为1,也凑不出amount+1
        Arrays.fill(dp,amount+1);
        //定初始值
        dp[0] = 0;

        for(int i = 0;i<coins.length;i++){
            int money = coins[i];
            for(int sum = money;sum<=amount;sum++){
                dp[sum] = Math.min(dp[sum],dp[sum-money]+1);
            }
        }
        return dp[amount]>amount ? -1:dp[amount];
    }
}

时间复杂度:O(N*S) N是coins数组长度,S是金额大小

空间复杂度:O(S)

相关推荐
凯瑟琳.奥古斯特1 小时前
力扣2760 C++滑动窗口解法
数据结构·c++·算法·leetcode·职场和发展
Hesionberger1 小时前
LeetCode96: 不同的二叉搜索树(多解)
算法
_深海凉_1 小时前
LeetCode热题100-不同路径
算法·leetcode·职场和发展
ZPC82101 小时前
CPU 核心隔离 + 线程绑核 + 实时优先级 SCHED_FIFO
人工智能·算法·计算机视觉·机器人
andafaAPS1 小时前
安达发|aps自动排产排程排单软件:日化生产高效运转“数字魔法”
大数据·人工智能·算法·aps软件·安达发aps·aps自动排产排程排单软件
黎阳之光1 小时前
全域实景立体管控:数字孪生与视频孪生技术体系白皮书
大数据·人工智能·算法·安全·数字孪生
88号技师2 小时前
2026年4月一区SCI-狒狒优化算法Baboon optimization algorithm-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
凯瑟琳.奥古斯特3 小时前
BFS解力扣1654最短跳跃次数
数据结构·算法·广度优先
sg_knight3 小时前
第一次用 OpenClaw,我让它 3 分钟写了个小工具
算法·llm·agent·ai编程·openclaw