leetcode:518. 零钱兑换 II[完全背包]

学习要点

  1. 理解完全背包思想
  2. 理解一维数组的解法

题目链接

518. 零钱兑换 II - 力扣(LeetCode)

题目描述

解法:二维数组

cpp 复制代码
class Solution {
public:
    int change(int amount, vector<int>& coins) {
        if (amount == 0)
            return 1;
        // dp[i][j]  0-i中任意无限取凑成j的最大方式
        int n = coins.size();
        vector<vector<uint64_t >> dp(n, vector<uint64_t>(amount + 1, 0));
        // 初始化
        for (int i = 1; i <= amount; i++) {
            if (i % coins[0] == 0) {
                dp[0][i] = 1;
            }
        }
        for (int i = 0; i < n; i++) {

            dp[i][0] = 1;
        }

        // 开始动归
        for (int i = 1; i < n; i++) {
            for (int j = 1; j <= amount; j++) {
                if (coins[i] > j) {
                    dp[i][j] = dp[i - 1][j];
                } else {
                    dp[i][j] = dp[i - 1][j] + dp[i][j - coins[i]];
                }
            }
        }
        return dp[n - 1][amount];
    }
};

解法:一维数组

cpp 复制代码
class Solution {
public:
    int change(int amount, vector<int>& coins) {
        // 完全背包组合问题
        if(amount == 0) return 1;
        int n = coins.size();
        vector<uint64_t> dp(amount+1,0);
        // dp[j] = dp[j]上一层 + dp[j-coins[i]]这一层 
        dp[0] = 1;
        for(int i = 0;i<n;i++)
        {
            for(int j = coins[i];j<=amount;j++)
            {
               dp[j] += dp[j-coins[i]]; 
            }
        }
        return dp[amount];
    }
};
相关推荐
sali-tec7 小时前
C# 基于halcon的视觉工作流-章66 四目匹配
开发语言·人工智能·数码相机·算法·计算机视觉·c#
小明说Java7 小时前
常见排序算法的实现
数据结构·算法·排序算法
行云流水20198 小时前
编程竞赛算法选择:理解时间复杂度提升解题效率
算法
smj2302_796826529 小时前
解决leetcode第3768题.固定长度子数组中的最小逆序对数目
python·算法·leetcode
cynicme10 小时前
力扣3531——统计被覆盖的建筑
算法·leetcode
core51210 小时前
深度解析DeepSeek-R1中GRPO强化学习算法
人工智能·算法·机器学习·deepseek·grpo
mit6.82410 小时前
计数if|
算法
a伊雪11 小时前
c++ 引用参数
c++·算法
圣保罗的大教堂11 小时前
leetcode 3531. 统计被覆盖的建筑 中等
leetcode