当前位置: 首页 > news >正文

python-leetcode-零钱兑换 II

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

这个问题是 完全背包问题 的一个变体,可以使用 动态规划 来解决。我们定义 dp[i] 为凑成金额 i 的硬币组合数。

思路:

  1. 定义 DP 数组
    dp[i] 表示凑成金额 i 的组合数,初始化 dp[0] = 1(金额为 0 时只有一种方式,即不选取任何硬币)。

  2. 状态转移方程
    对于每个硬币 coin,遍历 dp[j](从 coinamount),更新 dp[j]

    dp[j]+=dp[j−coin]dp[j] += dp[j - coin]dp[j]+=dp[j−coin]

    这表示我们可以用 coin 这个硬币来扩展 dp[j - coin] 形成的新组合。

  3. 遍历顺序

  • 外层遍历硬币(确保组合的唯一性)
  • 内层遍历金额(从 coinamount
  • 这样保证了组合是无序的,不会重复计算顺序不同但硬币相同的组合。
class Solution:
    def change(self, amount: int, coins: List[int]) -> int:  
        dp = [0] * (amount + 1)
        dp[0] = 1  # 凑出金额 0 只有一种方式,即什么都不选
        
        for coin in coins:  # 遍历每种硬币
            for j in range(coin, amount + 1):  # 遍历金额
                dp[j] += dp[j - coin]  # 累加组合数
                
        return dp[amount]

复杂度分析

  • 时间复杂度:O(n × m),其中 namountmcoins 的数量。
  • 空间复杂度:O(n),只使用了一维 dp 数组。

总结

这个问题可以通过 动态规划 解决,核心思想是:

  • dp[j] += dp[j - coin] 这一公式表示用 coin 形成新组合。
  • 遍历硬币优先,确保组合的唯一性。
  • 空间优化:只使用一维数组 dp
http://www.dtcms.com/a/51614.html

相关文章:

  • EasyRTC嵌入式视频通话SDK的跨平台适配,构建web浏览器、Linux、ARM、安卓等终端的低延迟音视频通信
  • 内核编程七:Linux 内核日志的级别
  • DeepSeek大模型深度解析:架构、技术与应用全景
  • SAP-ABAP:SAP第二代增强之隐式增强(Implicit Enhancements)和Enhancement Framework 的详细解析
  • 密码学(一)
  • 混合专家模型(MoE):高效处理复杂任务的智能架构,DeepSeek性能出色的秘诀
  • SpringCloud微服务开发工程细节
  • 1.15-16-17-18迭代器与生成器,函数,数据结构,模块
  • LeetCode 718.最长重复子数组(动态规划,Python)
  • DeepSeek学术写作全流程提示词
  • LLM自动金融量化-CFGPT
  • 肠胃镜过程描述(普通、无痛)
  • 学习记录-缺陷
  • 如何用FFmpeg高效拉流(避坑指南)
  • 数据库原理4
  • 为AI聊天工具添加一个知识系统 之135 详细设计之76 通用编程语言 之6
  • java项目之基于ssm的在线视频网站开发(源码+文档)
  • java8中young gc的垃圾回收器选型,您了解嘛
  • 基于SpringBoot+mybatis+layui就业管理系统设计和实现
  • Git安装与配置
  • 第一个 C++ 程序
  • C++————引用
  • SpringTask 引起的错误
  • 【折线图 Line】——12
  • PHP之常量
  • [数据结构]设计循环队列
  • 【由技及道】量子构建交响曲:Jenkinsfile流水线的十一维编程艺术【人工智障AI2077的开发日志008】
  • SpringMvc与Struts2
  • 【Linux】命名管道
  • 影刀RPA开发拓展--正则表达式