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

python-leetcode-使用最小花费爬楼梯

746. 使用最小花费爬楼梯 - 力扣(LeetCode)

解法 1:动态规划(O(n) 时间,O(n) 空间)

class Solution:
    def minCostClimbingStairs(self, cost: List[int]) -> int:
        n = len(cost)
        dp = [0] * (n + 1)  # 额外多一个 dp[n]
        
        for i in range(2, n + 1):
            dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2])
        
        return dp[n]

优点:清晰直观,容易理解。
⚠️ 缺点:需要 O(n) 额外空间存储 dp 数组。

解法 2:动态规划 + 空间优化(O(n) 时间,O(1) 空间)

优化思路

  1. 由于 dp[i] 仅依赖 dp[i-1]dp[i-2],因此可以用 两个变量 代替 dp 数组,优化空间。
  2. prev2 表示 dp[i-2]prev1 表示 dp[i-1]curr 表示 dp[i]
class Solution:
    def minCostClimbingStairs(self, cost: List[int]) -> int:
        n = len(cost)
        prev2, prev1 = 0, 0  # 对应 dp[0] 和 dp[1]
        
        for i in range(2, n + 1):
            curr = min(prev1 + cost[i - 1], prev2 + cost[i - 2])
            prev2, prev1 = prev1, curr  # 滚动更新
        
        return prev1

优点O(1) 空间复杂度,适用于大规模输入。
缺点:相比数组版本,可读性稍差。

解法 3:原地修改(O(n) 时间,O(1) 空间)

思路

直接修改 cost 数组,使 cost[i] 存储到达 i 级台阶的最小花费,最终返回 min(cost[-1], cost[-2])

class Solution:
    def minCostClimbingStairs(self, cost: List[int]) -> int:
        n = len(cost)
    
        for i in range(2, n):
            cost[i] += min(cost[i - 1], cost[i - 2])
        
        return min(cost[-1], cost[-2])

优点:无需额外变量,直接在原数组上计算,节省空间。
⚠️ 缺点会修改输入数据,如果 cost 需要保留,不能用此方法。

最佳选择

方法时间复杂度空间复杂度适用情况
DP 数组O(n)O(n)适用于小规模输入,代码易理解
DP + 滚动数组O(n)O(1)推荐,适合大规模输入
原地修改O(n)O(1)适用于不需要保留 cost 数组

🔹 小规模输入(n < 1000),DP 数组版可读性好。
🔹 大规模输入(n > 10^6),推荐 滚动变量版(O(1) 空间)
🔹 如果可以修改 cost 数组,可以用 原地修改版

相关文章:

  • 【JSON2WEB】15 银河麒麟操作系统下部署JSON2WEB
  • 【计算机网络】TCP三次握手,四次挥手以及SYN,ACK,seq,以及握手次数理解
  • Opencv之sift特征检测和FLANN 匹配器进行指纹特征匹配
  • StableDiffusion本地部署 3 整合包猜想
  • 2-3文件的属性信息
  • Pycharm中怎么加快下载三方包速度
  • Mplayer TUI增强设计:Linux命令行播放器的效率革命
  • 算法之数据结构
  • LangChain原理解析及开发实战指南(2025年最新版)
  • 基于SpringBoot的环保网站的设计与实现(源码+SQL脚本+LW+部署讲解等)
  • Android 应用开发中,证书、签名和加固简述
  • Odoo免费开源CRM技术实战:从商机线索关联转化为售后工单的应用
  • 网站被sweet32攻击 漏洞修复
  • ARM学习(43)armcc HardFault函数链接不到的问题理解
  • 3-4 WPS JS宏 工作表的新建、删除与错务内容处理(批量新建工作表)学习笔记
  • VUE2生命周期页面加载顺序
  • How to use VRX on ubuntu20.04 with ROS1 Noetic?[2]
  • Python 函数高级特性:从默认参数到闭包的全面解析
  • 偏移量是什么
  • 图书数据采集:使用Python爬虫获取书籍详细信息
  • 网站开发费用周期/百度开发平台
  • 深圳网站关键词优化排名/谷歌seo搜索引擎
  • php网站如何做特效/打广告在哪里打最有效
  • 教育考试类网站建设/查域名
  • 聊城做网站公司/南宁在哪里推广网站
  • 网站建设中销售人员会问客户的问题/怎样做网站的优化、排名