首页 > 其他分享 >70. 爬楼梯

70. 爬楼梯

时间:2023-12-14 17:56:06浏览次数:17  
标签:台阶 递归 stair int sqrt5 climbStairs 70 爬楼梯

1.题目介绍

假设你正在爬楼梯。需要 \(n\) 阶你才能到达楼顶。

每次你可以爬 \(1\) 或 \(2\) 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶

示例 2:

输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1. 1 阶 + 1 阶 + 1 阶
2. 1 阶 + 2 阶
3. 2 阶 + 1 阶

提示:

  • \(1 <= n <= 45\)

2.题解

2.1 方法一:动态规划

思路

我们用 f(x) 表示爬到第 xxx 级台阶的方案数,考虑最后一步可能跨了一级台阶,也可能跨了两级台阶,所以我们可以列出如下式子:
f(x) = f(x - 1) + f(x - 2)
它意味着爬到第 x 级台阶的方案数是爬到第 x−1级台阶的方案数和爬到第 x−2 级台阶的方案数的和,因为每次只能爬 1 级或 2 级台阶

边界条件。我们是从第 0 级开始爬的,所以从第 0级爬到第 0 级我们可以看作只有一种方案,即 f(0)=1;
从第 0 级到第 1 级也只有一种方案,即爬一级,f(1)=1。 这两个作为边界条件就可以继续向后推导出第 n 级的正确结果。

我们不难通过转移方程和边界条件给出一个时间复杂度和空间复杂度都是 O(n) 的实现,
但是由于这里的 f(x) 只和 f(x−1)与 f(x−2) 有关,所以我们可以用「滚动数组思想」把空间复杂度优化成 O(1)。下面的代码中给出的就是这种实现。
image

代码

class Solution {
public:
    int climbStairs(int n) {
        int p = 0, q = 0, r = 1;
        for (int i = 1; i <= n; ++i){
            p = q;
            q = r;
            r = p+q;
        }
        return r;
    }
};

2.2 矩阵快速幂(待进一步理解)

思路

image
image

代码


2.3 通项公式

思路

是的,你的描述涉及到使用特征方程求解齐次线性递推的通项公式。这是一种常见的方法,特别是在处理斐波那契数列或类似问题时。

具体步骤如下:
image

代码

class Solution {
public:
    int climbStairs(int n) {
        double sqrt5 = sqrt(5);
        double fibn = pow((1 + sqrt5) / 2, n + 1) - pow((1 - sqrt5) / 2, n + 1);
        return (int)round(fibn / sqrt5);
    }
};

作者:力扣官方题解
链接:https://leetcode.cn/problems/climbing-stairs/solutions/286022/pa-lou-ti-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

2.4 递归

思路

递归很容易递归层数过深导致时间超过限制
这里最巧妙的一点是用数组记录每层楼梯到达的方法数,
当其余递归到该层的时候,就不需要再继续进行递归,直接返回递归的方法数即可
用空间换时间

代码

class Solution {
public:
    int stair[46]; // 记录每层的种类数
    int climbStairs(int n) {
        if(n == 1 || n == 2) {
            stair[n] = n;
            return stair[n];
        }
        stair[n] += stair[n-1] ? stair[n-1] : climbStairs(n-1);
        stair[n] += stair[n-2] ? stair[n-2] : climbStairs(n-2);
        return stair[n];
    }
};

标签:台阶,递归,stair,int,sqrt5,climbStairs,70,爬楼梯
From: https://www.cnblogs.com/trmbh12/p/17901691.html

相关文章

  • 关于找不到指定的模块,异常来自HRESULT:0x8007007E的解决方法
    原文链接:https://www.cnblogs.com/ReBack2010/p/3713851.html上午从公司前辈那里拷贝到的ASP.NET代码,在自己机器上部署的时候发现问题,直接报错,找不到指定的模块,异常来自HRESULT:0x8007007E。并且一大堆警告。在网上百度很多解决方法,归纳如下:1、缺少DLL文件,我用depends打开我的B......
  • 秦疆的Java课程笔记:70 面向对象 方法重写
    重写都是方法的重写,和属性没有关系。//父类写一个静态方法======================publicclassA{publicstaticvoidtest(){System.out.println("A=>test()");}}//子类也写一个静态方法====================publicclassBextendsA{......
  • 代码随想录算法训练营第一天|704.二分查找、27.移除元素
    LeetCode704二分查找题目链接704.二分查找二分法确定区间(循环不变量):对于有序数组,定义循环区间二分查找元素 LeetCode27.移除元素题目链接:27.移除元素快慢指针,快指针查,慢指针存 ......
  • 代码随想录算法训练营第一天 | 数组理论基础,704. 二分查找,27. 移除元素
    一、数组理论基础学习前:1.数组定义一些在内存上连续存储的相同数据类型的数据的集合2.数组特征便于查询数组元素,不便于增删数据元素学习后:对于Java,二维数组不一定在内存上连续。如int[i][j],唯一确定的是int[i][]在内存上连续二、704.二分查找LeetCode704.二分查找......
  • 代码随想录算法训练营第一天| LeetCode704 二分查找、27移除元素
     Leetcode704:二分查找今日学习的文章链接:代码随想录(programmercarl.com) 题目链接:704.二分查找-力扣(LeetCode)●  自己看到题目的第一想法这题我会,但是还没明白卡尔说的循环不变量是什么意思。我的固定思路就是,target比中间值大,左指针右移到mid+1;target比中间值......
  • 代码随想录算法训练营Day1 | 704.二分查找、27.移除元素
    LeetCode704.二分查找二分查找是一种基础的算法,其核心思想在高中数学中就已经被大家所熟知了,然而对于代码的实现,其细节问题常常令人头疼,比如while循环的条件是什么?middle是该+1还是-1?这些问题需要有一个清晰的认知。题目链接如下:704.二分查找Carl的讲解链接:二分查找算法......
  • selenium运行时的ValueError: Timeout value connect was <object object at 0x000001
    fromseleniumimportwebdriverdriver=webdriver.Chrome()driver.get("https://www.baidu.com/")运行时出现ValueError:Timeoutvalueconnectwas<objectobjectat0x000001FE483C4170>错误大概率原因是:selenium和urllib3库的版本冲突导致修改版本为:selenium=3.1......
  • [CF704E] Iron man
    题目链接树的情况不好做。先树剖,现在变成了链的问题。考虑对时间扫描线,会发现所有人的相对顺序变化的时候,就是有人相遇了。所以他的相对顺序可以用一个set维护。而将会相遇的人一定是插入时相对顺序相邻的人,可以check一下取个最小值。可以把时间线设成全局变量,这样就可以跑......
  • P4170 [CQOI2007] 涂色(天赋哥不要点进来)
    前言翻遍洛谷题解,看到大家都在套模板,却很少有人讲出为什么,使我十分崇拜天赋哥。原题链接关于这题的一些事实性证据事实1.来自事实2.来自事实3.来自事实4.来自整理上述事实1.每一次”最短“最优涂色,要么在其他颜色的基础上涂,这称之为融入一个整体;要么另辟蹊径单独......
  • 力扣70-爬楼梯
    该题难度为【简单】第一遍:暴力解法,写了一个递归,时间复杂度特别高,提交后显示“超时”。第二遍:看了一遍官方的题解后,使用了一个临时变量保存每一步的计算结果,先查询是否已经计算过,如果查不到结果再计算。提交后显示“通过”。第三遍:看官方解法的时候,我是先看代码的,完全看不懂为什......