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

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

需强化知识点

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

题目

518. 零钱兑换 II

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. 组合总和 Ⅳ

  • 完全背包:排列问题,先重量后物品
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]
        

最近更新

  1. TCP协议是安全的吗?

    2024-06-11 11:46:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-11 11:46:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-11 11:46:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-11 11:46:01       18 阅读

热门阅读

  1. 在 RISC-V 设计中发现可远程利用的漏洞

    2024-06-11 11:46:01       9 阅读
  2. VK Cup 2015 - Round 1 C. The Art of Dealing with ATM

    2024-06-11 11:46:01       12 阅读
  3. Kappa架构介绍

    2024-06-11 11:46:01       10 阅读
  4. Eureka和Nacos有哪些区别?

    2024-06-11 11:46:01       9 阅读