!力扣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;
    }
};
相关推荐
YUDAMENGNIUBI1 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2075 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎6 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM7 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮7 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮8 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程
橙淮8 小时前
双指针法:高效算法解题的利器
算法
初心未改HD8 小时前
深度学习之MLP与反向传播算法详解
人工智能·深度学习·算法
刀法如飞8 小时前
【Go 字符串查找的 20 种实现方式,用不同思路解决问题】
人工智能·算法·go