!力扣70. 爬楼梯

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

1. 递归(超时)

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的数组)

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层有关,因此只需两个变量记录之前的状态即可。

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;
    }
};

相关推荐

  1. 70. 楼梯

    2024-06-09 14:30:04       37 阅读
  2. 70.楼梯

    2024-06-09 14:30:04       7 阅读
  3. 70. 楼梯

    2024-06-09 14:30:04       10 阅读
  4. 70. 楼梯

    2024-06-09 14:30:04       9 阅读
  5. 70. 楼梯(三种解法)

    2024-06-09 14:30:04       21 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-09 14:30:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-09 14:30:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-09 14:30:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-09 14:30:04       20 阅读

热门阅读

  1. 微信小程序:实现音乐播放器的功能

    2024-06-09 14:30:04       6 阅读
  2. oracle10g的dataguard测试

    2024-06-09 14:30:04       12 阅读
  3. 电商系统中热库和冷库的使用与数据转换

    2024-06-09 14:30:04       8 阅读
  4. Python R用法:深度探索与实用技巧

    2024-06-09 14:30:04       9 阅读
  5. K-means聚类模型

    2024-06-09 14:30:04       10 阅读
  6. RAGFlow 学习笔记

    2024-06-09 14:30:04       10 阅读
  7. tcpdump 抓包

    2024-06-09 14:30:04       9 阅读
  8. TypeScript看这篇就够了

    2024-06-09 14:30:04       12 阅读
  9. 【分享】使用 Reducer 和 Context 拓展你的应用

    2024-06-09 14:30:04       13 阅读
  10. 力扣2799.统计完全子数组的数目

    2024-06-09 14:30:04       11 阅读