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];
    }
};
相关推荐
墨染点香1 小时前
LeetCode 刷题【103. 二叉树的锯齿形层序遍历、104. 二叉树的最大深度、105. 从前序与中序遍历序列构造二叉树】
算法·leetcode·职场和发展
啊我不会诶1 小时前
23ICPC澳门站补题
算法·深度优先·图论
Brookty2 小时前
【算法】二分查找(一)朴素二分
java·学习·算法·leetcode·二分查找
黑色的山岗在沉睡3 小时前
LeetCode 2761. 和等于目标值的质数对
算法·leetcode·职场和发展
bawangtianzun3 小时前
重链剖分 学习记录
数据结构·c++·学习·算法
T1an-17 小时前
力扣70.爬楼梯
算法·leetcode·职场和发展
T1an-17 小时前
力扣169.多数元素
数据结构·算法·leetcode
我命由我1234511 小时前
Photoshop - Photoshop 工具栏(5)多边套索工具
笔记·学习·ui·职场和发展·photoshop·ps·美工
_dindong12 小时前
动规:回文串问题
笔记·学习·算法·leetcode·动态规划·力扣
wangwangmoon_light13 小时前
0.0 编码基础模板
java·数据结构·算法