!力扣70. 爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 12 个台阶。你有多少种不同的方法可以爬到楼顶呢?

1. 递归(超时)

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        if(n==1){return 1;}
        if(n==2){return 2;}
        return climbStairs(n-1)+climbStairs(n-2);

    }
};

2. 迭代(需要开大小为n+1的数组)

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        vector<int> f(n+1,0);//大小为n+1的int数组,初始化为0
        f[0]=1;f[1]=1;//爬0层楼梯有一种方法,1层楼梯有两种方法

        for(int i=2;i<n+1;i++){//从0累加到n共n+1个数
            f[i]=f[i-1]+f[i-2];//第i层楼梯的方法数为i-1层爬一个台阶加i-2层爬二个台阶
        }
        return f[n];
    }
};

3. 滚动数组

f[i]=f[i-1]+f[i-2]第 i 层状态只与第i-1层和i-2层有关,因此只需两个变量记录之前的状态即可。

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {      
        int a=1,b=1;//a=f[i-2],b=f[i-1]
        int c;//c=f[i]
        for(int i=2;i<n+1;i++){//从0累加到n共n+1个数
            c=a+b;
            a=b;
            b=c;
        }
        return c;
    }
};
相关推荐
前端小L1 小时前
贪心算法专题(十):维度权衡的艺术——「根据身高重建队列」
javascript·算法·贪心算法
方得一笔1 小时前
自定义常用的字符串函数(strlen,strcpy,strcmp,strcat)
算法
Xの哲學2 小时前
Linux SMP 实现机制深度剖析
linux·服务器·网络·算法·边缘计算
wuk9982 小时前
使用PCA算法进行故障诊断的MATLAB仿真
算法·matlab
额呃呃2 小时前
二分查找细节理解
数据结构·算法
无尽的罚坐人生2 小时前
hot 100 283. 移动零
数据结构·算法·双指针
永远都不秃头的程序员(互关)3 小时前
C++动态数组实战:从手写到vector优化
c++·算法
水力魔方3 小时前
武理排水管网模拟分析系统应用专题5:模型克隆与并行计算
数据库·c++·算法·swmm
谈笑也风生4 小时前
经典算法题型之排序算法(三)
java·算法·排序算法
大佬,救命!!!5 小时前
对算子shape相关的属性值自动化处理
python·算法·自动化·学习笔记·算子·用例脚本·算子形状