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];
    }
};
相关推荐
阿豪学编程3 小时前
LeetCode724.:寻找数组的中心下标
算法·leetcode
墨韵流芳3 小时前
CCF-CSP第41次认证第三题——进程通信
c++·人工智能·算法·机器学习·csp·ccf
csdn_aspnet4 小时前
C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·算法·c#
禹中一只鱼4 小时前
【力扣热题100学习笔记】 - 哈希
java·学习·leetcode·哈希算法
凌波粒4 小时前
LeetCode--349.两个数组的交集(哈希表)
java·算法·leetcode·散列表
paeamecium6 小时前
【PAT甲级真题】- Student List for Course (25)
数据结构·c++·算法·list·pat考试
Book思议-6 小时前
【数据结构】栈与队列全方位对比 + C 语言完整实现
c语言·数据结构·算法··队列
SteveSenna6 小时前
项目:Trossen Arm MuJoCo
人工智能·学习·算法
NAGNIP6 小时前
一文搞懂CNN经典架构-DenseNet!
算法·面试
道法自然|~6 小时前
BugCTF黄道十二宫
算法·密码学