力扣_爬楼梯

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

复制代码
假设你正在爬楼梯。需要 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
相关推荐
hakesashou9 分钟前
python 随机函数可以生成字符串吗
开发语言·python
FakeOccupational11 分钟前
【经济学】 基本面数据(Fundamental Data)之 美国劳动力报告&非农就业NFP + ADP + 美国劳动力参与率LFPR
开发语言·人工智能·python
weixin_4130632116 分钟前
测试《A Simple Algorithm for Fitting a Gaussian Function》拟合
python·算法
MarkHD26 分钟前
智能体在车联网中的应用:第31天 基于RLlib的多智能体PPO实战:MAPPO算法解决simple_spread合作任务
算法
IT猿手28 分钟前
三维动态避障路径规划:基于部落竞争与成员合作算法(CTCM)融合动态窗口法DWA的无人机三维动态避障方法研究,MATLAB代码
算法·matlab·动态规划·无人机·路径规划·动态路径规划
郝学胜-神的一滴29 分钟前
机器学习数据集完全指南:从公开资源到Sklearn实战
人工智能·python·程序人生·机器学习·scikit-learn·sklearn
不要em0啦33 分钟前
从0开始学python:简单的练习题3
开发语言·前端·python
不要em0啦43 分钟前
从0开始学python:判断与循环语句
开发语言·python
OC溥哥99944 分钟前
2D我的世界创造模式网页版正式出炉——《我们的2D创造世界:无限创意,多人同乐》欢迎来到ourcraft.xin网站上玩
后端·python·阿里云·flask·html·游戏程序
wadesir1 小时前
Java实现遗传算法(从零开始掌握智能优化算法)
java·开发语言·算法