LeetCode热题100 爬楼梯

题目描述

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

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

示例 1:

输入 :n = 2
输出 :2
解释 :有两种方法可以爬到楼顶。

1 1 阶 + 1 阶

2 2 阶

示例 2:

输入 :n = 3
输出 :3
解释 :有三种方法可以爬到楼顶。

1 1 阶 + 1 阶 + 1 阶

2 1 阶 + 2 阶

3 2 阶 + 1 阶

提示:

1 <= n <= 45

思路

动态规划模板,f[i]表示第i步的方法数,转移方程为:f[i] = f[i - 1] + f[i - 2]。

代码

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        int p = 0, q = 0, r = 1;
        for(int i = 1; i <= n; ++i)
        {
            p = q, q = r, r = p + q;            
        }   
        return r;
    }
};
相关推荐
算法鑫探2 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
IronMurphy2 小时前
【算法三十七】51. N 皇后
算法·深度优先
DoUfp0bgq2 小时前
从直觉到算法:贝叶斯思维的技术底层与工程实现
算法
少司府2 小时前
C++基础入门:类和对象(中)
c语言·开发语言·c++·类和对象·运算符重载·默认成员函数
ThisIsMirror2 小时前
leetcode 452 Arrays.sort()排序整数溢出、Integer.compare(a[1], b[1])成功的问题
算法·leetcode
王老师青少年编程2 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举
wayz112 小时前
数据分析中的异常值处理:MAD
算法·数据挖掘·数据分析
飞Link2 小时前
LangGraph 核心架构解析:节点 (Nodes) 与边 (Edges) 的工作机制及实战指南
java·开发语言·python·算法·架构
Mr_Xuhhh3 小时前
深入理解二叉树:从数据结构到算法实战
数据结构·算法