LeetCode 518:零钱兑换 II(Coin Change II)—— 题解 ✅

LeetCode 518:零钱兑换 II(Coin Change II)------ 题解 ✅

📖 内容概要

给定不同面额的硬币 coins 和一个总金额 amount

计算 凑成总金额的组合数(每种硬币无限使用)。

✅ 完全背包

✅ 组合问题(不计顺序)

✅ 遍历顺序极其关键


💡 解题思路

一、问题本质

  • 硬币数量无限
  • 只关心 金额是否凑成
  • 只统计 组合数(不计顺序)

👉 典型的 完全背包(组合计数)


二、DP 定义

java 复制代码
dp[j] = 凑成金额 j 的组合数

三、状态转移方程

java 复制代码
dp[j] += dp[j - coins[i]]

含义:

  • 使用当前硬币 coins[i]
  • 新增的组合数 = 凑成 j - coins[i] 的方法数

🔥 核心重点:遍历顺序

✅ 正确的遍历顺序(本题)

java 复制代码
for (int i = 0; i < coins.length; i++) {      // 物品
    for (int j = coins[i]; j <= amount; j++) { // 背包
        dp[j] += dp[j - coins[i]];
    }
}
为什么这样写?
层级 含义
外层 i 枚举硬币种类
内层 j 枚举金额

保证硬币按顺序使用

不会出现 1+22+1 重复

✅ 得到的是 组合数


❌ 错误的遍历顺序

java 复制代码
for (int j = 0; j <= amount; j++) {
    for (int i = 0; i < coins.length; i++) {
        dp[j] += dp[j - coins[i]];
    }
}

❌ 会统计排列数

1+22+1 被视为不同方案


🔑 记忆口诀

求组合数:先物品,后背包

求排列数:先背包,后物品


✅ AC 代码(Java)

java 复制代码
class Solution {
    public int change(int amount, int[] coins) {
        int[] dp = new int[amount + 1];
        dp[0] = 1; // 凑成金额 0 有 1 种方式

        // 先遍历硬币(物品)
        for (int i = 0; i < coins.length; i++) {
            // 再遍历金额(背包)
            for (int j = coins[i]; j <= amount; j++) {
                dp[j] += dp[j - coins[i]];
            }
        }
        return dp[amount];
    }
}

⏱️ 复杂度分析

指标 复杂度
时间复杂度 O(coins.length × amount)
空间复杂度 O(amount)

✅ 一句话总结

完全背包 + 组合计数 = 外层硬币、内层金额,正序遍历。

相关推荐
兰令水1 小时前
leecodecode【回溯组合】【2026.6.5打卡-java版本】
java·开发语言
计算机安禾1 小时前
【算法分析与设计】第49篇:算法博弈论与机制设计
人工智能·算法·机器学习
cfm_29141 小时前
SpringBoot整合RocketMQ极速实战
java·spring boot·后端
为爱停留1 小时前
让智能体「记住」对话:Checkpoint 功能、持久化数据接口与 thread_id 详解
java·数据库·elasticsearch
Sylvia33.1 小时前
2026世界杯全套数据API接入教程:WebSocket实时进球推送实例
java·网络·python·websocket·网络协议
linge_sun1 小时前
SpringAI 功能体验之SQL智能助手:用自然语言查询数据库
java·人工智能·ai编程
05候补工程师1 小时前
【408 数据结构】图论核心算法(拓扑/关键路径)与二叉搜索树精髓夺分笔记
数据结构·经验分享·笔记·考研·算法·图论
AC赳赳老秦1 小时前
OpenClaw+MySQL 深度应用:自动生成建表语句、索引优化建议与数据迁移脚本
开发语言·数据库·人工智能·python·mysql·算法·openclaw
奔袭的算法工程师1 小时前
论文解读--BEV-radar:: bidirectional radar-camera fusion for 3D object detection
人工智能·算法·目标检测·计算机视觉·自动驾驶·信号处理