【Day28】LeetCode:509. 斐波那契数,70. 爬楼梯,746. 使用最小花费爬楼梯

文章目录

  • [LeetCode:509. 斐波那契数](#LeetCode:509. 斐波那契数)
  • [LeetCode:70. 爬楼梯](#LeetCode:70. 爬楼梯)
  • [LeetCode:746. 使用最小花费爬楼梯](#LeetCode:746. 使用最小花费爬楼梯)

LeetCode:509. 斐波那契数

https://leetcode.cn/problems/fibonacci-number/

思路

状态转移方程 dp[i] = dp[i - 1] + dp[i - 2] .

解答

python 复制代码
class Solution:
    def fib(self, n: int) -> int:
        if n == 0:
            return 0
        elif n == 1:
            return 1

        dp0 = 0
        dp1 = 1
        
        for i in range(2, n + 1):
            temp_sum = dp0 + dp1
            dp0 = dp1
            dp1 = temp_sum
        
        return dp1

LeetCode:70. 爬楼梯

https://leetcode.cn/problems/climbing-stairs/

思路

爬 n 级楼梯的爬法,可以从 n -1 级跨 1 个台阶,也可以从 n - 2 级跨 2 个台阶。即 dp[i] = dp[i - 1] + dp[i - 2]

解答

python 复制代码
class Solution:
    def climbStairs(self, n: int) -> int:
        if n == 1:
            return 1

        if n == 2:
            return 2
        
        dp1 = 1
        dp2 = 2

        for i in range(3, n + 1):
            temp_sum = dp1 + dp2
            dp1 = dp2
            dp2 = temp_sum
        
        return dp2

LeetCode:746. 使用最小花费爬楼梯

https://leetcode.cn/problems/min-cost-climbing-stairs/description/

思路

用 dp 数组记录到每个下标的最小耗费,要登顶则 i == n,刚好越界。则状态转移方程为:dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]) ,即要到 i 处考虑从 i - 1 处消耗 cost[i-1] 跳 1 级,或从 i - 2 处消耗 cost[i-2] 跳 2 级。

解答

python 复制代码
class Solution:
    def minCostClimbingStairs(self, cost: List[int]) -> int:
        n = len(cost)

        dp = [None] * (n + 1) # 记录到每个下标的最小耗费,要登顶则 i == n,刚好越界

        dp[0] = 0 # 直接从 cost[0] 或 cost[1] 出发,不消耗
        dp[1] = 0
        
        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]
相关推荐
兵慌码乱12 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵13 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio17 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
kisshyshy17 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
用户03321266636718 小时前
使用 Python 从零创建 Word 文档
python
Csvn1 天前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定
后端·python
曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
猿人谷1 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
用户556918817531 天前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维
复杂网络1 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法