leetcode 70. 爬楼梯 easy 动态规划 斐波那契数列


初始条件:

f(1) = 1 (只有 1 阶 → 只有 1 种方法)

f(2) = 2 (两阶 → 1+1 或 2)

假设 f(n) 表示爬到第 n 阶楼梯的方法数:

最后一步是 1 阶 → 前面已经爬到第 n-1 阶 → 有 f(n-1) 种方法

最后一步是 2 阶 → 前面已经爬到第 n-2 阶 → 有 f(n-2) 种方法

所以状态转移方程是:f(n)=f(n−1)+f(n−2)


方法 1:递归(指数级时间复杂度)

时间复杂度:O(2^n)

空间复杂度:O(n)(递归栈)

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

        # 最后一步是 1 阶 → 前面已经爬到第 n-1 阶 → 有 f(n-1) 种方法
        # 最后一步是 2 阶 → 前面已经爬到第 n-2 阶 → 有 f(n-2) 种方法

        # f(n)=f(n−1)+f(n−2)
        # 递归

        if n==1:
            return 1
        if n==2:
            return 2
        
        return self.climbStairs(n-1) + self.climbStairs(n-2)  # class中自己调自己,加self

超时


方法2: 动态规划

时间复杂度:O(n)

空间复杂度:O(1)

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

        # 最后一步是 1 阶 → 前面已经爬到第 n-1 阶 → 有 f(n-1) 种方法
        # 最后一步是 2 阶 → 前面已经爬到第 n-2 阶 → 有 f(n-2) 种方法

        # f(n)=f(n−1)+f(n−2)
        # 动态规划 时间复杂度:O(n), 空间复杂度:O(1)

        if n==1:
            return 1
        if n==2:
            return 2

        # 对第3层台阶来说
        prev2 = 1     # 上一步走了2步,还能再走1步
        prev1 = 2     # 上一步走了1步,还能再走2步

        for cur_floor in range(3, n+1):  #从第3层台阶开始,往上走到第n层台阶

            current = prev1 + prev2  #  前阶的走法数 f(n)=f(n−1)+f(n−2) 

            prev2 = prev1      # 对下一层台阶来说,cur_floor的f(n-1)是:下一层台阶的f(n-2)走法
            prev1 = current    # 对下一层台阶来说,cur_floor是f(n-1)的走法

        return current  
相关推荐
故事和你9110 小时前
洛谷-【图论2-1】树4
开发语言·数据结构·c++·算法·动态规划·图论
故事和你9110 小时前
洛谷-【图论2-1】树1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
敲代码的嘎仔10 小时前
力扣高频SQL基础50题详解
开发语言·数据库·笔记·sql·算法·leetcode·后端开发
洛水水12 小时前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
alphaTao15 小时前
LeetCode 每日一题 2026/5/11-2026/5/17
算法·leetcode
洛水水15 小时前
【力扣100题】45.零钱兑换
算法·leetcode·职场和发展
YL2004042615 小时前
041二叉树的层序遍历
数据结构·leetcode·bfs
洛水水16 小时前
【力扣100题】47.最长递增子序列
算法·leetcode·职场和发展
木子墨51617 小时前
工程算法实战 | 数据库ORDER BY的底层:内存排序 → 外部归并 → 索引优化
数据结构·数据库·python·sql·算法·动态规划
_日拱一卒18 小时前
LeetCode:199二叉树的右视图
算法·leetcode·职场和发展