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  
相关推荐
To_OC15 小时前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
To_OC3 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
To_OC4 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
-森屿安年-10 天前
63. 不同路径 II
c++·算法·动态规划
想吃火锅100510 天前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
凌波粒10 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
退休倒计时10 天前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript
小欣加油10 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒10 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
凌波粒10 天前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode