【代码随想录训练营】【Day 46】【动态规划-6】| Leetcode 518, 377

【代码随想录训练营】【Day 46】【动态规划-6】| Leetcode 518, 377

需强化知识点

  • 完全背包基础(遍历重量时 正序,保证物品可重复加入)
  • 完全背包:组合问题,先物品后重量,排列问题,先重量后物品

题目

518. 零钱兑换 II

python 复制代码
class Solution:
    def change(self, amount: int, coins: List[int]) -> int:
        # 金额 i 的 组成方式数量
        dp = [0] * (amount + 1)
        dp[0] = 1

        for coin in coins:
            for i in range(coin, amount + 1):
                dp[i] += dp[i-coin]
        
        return dp[amount]

377. 组合总和 Ⅳ

  • 完全背包:排列问题,先重量后物品
python 复制代码
class Solution:
    def combinationSum4(self, nums: List[int], target: int) -> int:
        # 总和为 i 的组合个数
        dp = [0] * (target+1)
        dp[0] = 1

        for i in range(1, target+1):
            for num in nums:
                if i >= num:
                    dp[i] += dp[i-num]
        
        return dp[target]
        
相关推荐
Youkiup40 分钟前
【重构数组,形成排列的最大长度】
算法
星夜孤帆1 小时前
LeetCode之图的广度优先搜索
算法·宽度优先
忍界英雄1 小时前
LeetCode: 673.最长子序列的数量 动态规划 时间复杂度O(n*n)
算法·leetcode·动态规划
Renascence.4091 小时前
力扣--649.Dota2参议院
java·数据结构·算法·leetcode
山脚ice1 小时前
【Hot100】LeetCode—62. 不同路径
算法·leetcode·职场和发展
小小工匠1 小时前
加密与安全_ sm-crypto 国密算法sm2、sm3和sm4的Java库
java·算法·安全·sm2·sm3·sm4
陈小唬2 小时前
树形结构构建的两种方式
java·数据库·算法
7yewh3 小时前
STM32常用数据采集滤波算法
stm32·嵌入式硬件·算法
不会编程的小江江3 小时前
【动态规划】(一)动态规划理论及基础题目
c++·算法·动态规划
qq_535246143 小时前
代码随想录 第九章 动态规划part03 01背包问题 一维 416. 分割等和子集
算法·动态规划·代理模式