【力扣C++】爬楼梯

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

每次你可以爬 12 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

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

示例 2:

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

通过规律观察发现:

楼顶数:1 2 3 4 5 6

方法数:1 2 3 5 8 13

1.递归

cpp 复制代码
int F(int n)
{
    if(n<=2)
        return n;
    else
        return F(n-1)+F(n-2);
}

2.记忆递归

cpp 复制代码
int arr[46]={0};
F(int n)
{
    if(n<=2)
        return n;
    if(arr[n]!=0)
        return arr[n];
    else
        return arr[n]=F(n-1)+F(n-2);
}

3.动态规划(减少了递归带来的内存申请)

cpp 复制代码
int F(int n){
    int arr[46]={0};
    arr[1]=1,arr[2]=2;
    for(int i=3;i<n+1;i++)
    {
        arr[i]=arr[i-1]+arr[i-2];
    }
    return arr[n];
}

4.滚动数组

cpp 复制代码
int F(int n) {
    int a = 0, b = 0, r = 1;
    for (int i = 1; i <= n; ++i) {
        a = b;
        b = r;
        r = a + b;
    }
    return r;
}
相关推荐
苏言の狗4 分钟前
小R的并集大小期望计算 | 蛮力
数据结构·算法
BineHello10 分钟前
MPC用优化求解器 - 解决无人机轨迹跟踪
算法·矩阵·自动驾驶·动态规划·无人机
誓约酱12 分钟前
(每日一题) 力扣 14 最长公共前缀
算法·leetcode·职场和发展
冠位观测者1 小时前
【Leetcode 每日一题 - 补卡】2070. 每一个查询的最大美丽值
数据结构·算法·leetcode
誓约酱1 小时前
(每日一题) 力扣 860 柠檬水找零
linux·c语言·c++·算法·leetcode·职场和发展
地平线开发者1 小时前
手把手基于 MINI 数据集带你做一次板端精度评估
算法·自动驾驶
詹天佐1 小时前
ICCE 数字车钥匙介绍
人工智能·算法
ak啊1 小时前
记忆化(Memoization)
算法
moonless02222 小时前
【Python】你还不了解数据结构与算法?
数据结构·算法·编程语言
z_y_j2299704382 小时前
L1-039 古风排版
c语言·数据结构·算法