力扣_爬楼梯

上班摸鱼,试试算法题摸摸鱼,题目如下:

复制代码
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
示例 1:
	输入:n = 2
	输出:2
解释:有两种方法可以爬到楼顶。
1 阶 + 1 阶
2 阶

示例 2:
输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1 阶 + 1 阶 + 1 阶
1 阶 + 2 阶
2 阶 + 1 阶
提示:
    1 <= n <= 45
    To reach nth step, what could have been your previous steps? (Think about the step sizes)
    要到达第n步,你之前的步骤是什么?(想想步长)

很明显如果要求10阶楼梯的答案需要求出9阶和8阶楼梯的答案,因此本题肯定是采用递归的方法来计算。假设n==10,那么func(10)=func(9)+func(8)...直到func(2)或者func(1)结束

下面是我第一次给出的答案

python 复制代码
class Solution:
    def climbStairs(self, n: int) -> int:
        if n >= 3:
            return self.climbStairs(n - 1) + self.climbStairs(n - 2)
        elif n == 2:
            return 2
        else:
            return 1

结果显示超过了时间的限制,有什么办法解决这个问题吗?在递归里面反复的计算了相同的内容,例如求func(3)的时候需要求func(2),求fun(4)时也需要求func(2)这就造成了时间的浪费,因此我们可以将一些计算结果存储下来减少计算量。

python 复制代码
class Solution:
    my_dict = {}

    def climbStairs(self, n: int) -> int:
        if self.my_dict.get(n) is not None:  # 先判断有没有计算过这个值
            return self.my_dict.get(n)
        tempResult = 0
        if n >= 3:
            tempResult = self.climbStairs(n - 1) + self.climbStairs(n - 2)
        elif n == 2:
            tempResult = 2
        else:
            tempResult = 1
        self.my_dict[n] = tempResult
        return tempResult
相关推荐
Fanxt_Ja10 小时前
Langchain+Tavily对接大模型实现联网搜索
python·langchain·deepseek·tavily
一个心烑10 小时前
【layui页面编辑下拉框处理的三种方式】
linux·python·layui
小的~~10 小时前
算法题:只出现一次的数字
数据结构·算法
灵智实验室10 小时前
PX4状态估计技术EKF2详解(六):EKF2 磁力计融合——从航向修正到 3D 姿态约束
算法·无人机·px 4
JieE21210 小时前
手把手带你用虚拟头节点实现单链表,搞定所有边界问题
javascript·算法
xingyuzhisuan10 小时前
2026实测:租用RTX 4090 CUDA适配与PyTorch精准安装教程
人工智能·pytorch·python·深度学习·gpu算力
嗯、.11 小时前
Agent 路由架构的一次尝试:LangGraph + Swarm Handoff + 小模型 Router
人工智能·python·swarm·langgraph·multi-agent·model-routing
SunnyDays101111 小时前
Java 实现插入和删除 Excel 行和列
java·python·excel
kels889911 小时前
加密货币实时api的订单簿快照多久更新一次?
开发语言·笔记·python·金融·区块链