!力扣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;
    }
};
相关推荐
闪电麦坤9522 分钟前
数据结构:图的表示 (Representation of Graphs)
数据结构·算法·图论
利以檀本人(梦泽不忙)38 分钟前
#T1359. 围成面积
c++·程序人生·算法
胡萝卜3.044 分钟前
【LeetCode&数据结构】设计循环队列
数据结构·算法·leetcode·队列·循环队列
徐归阳1 小时前
数组本身的深入解析
数据结构·c++·算法
白榆!2 小时前
string类的实现
开发语言·c++·算法
CHANG_THE_WORLD2 小时前
线程特定存储
算法·线程
ai产品老杨2 小时前
打破技术壁垒,推动餐饮食安标准化进程的明厨亮灶开源了
前端·javascript·算法·开源·音视频
睡不醒的kun2 小时前
leetcode算法刷题的第二十六天
数据结构·c++·算法·leetcode·职场和发展·贪心算法
fangzelin53 小时前
基础排序--冒泡--选择--插入
数据结构·c++·算法
THMAIL3 小时前
机器学习从入门到精通 - 卷积神经网络(CNN)实战:图像识别模型搭建指南
linux·人工智能·python·算法·机器学习·cnn·逻辑回归