力扣70.爬楼梯

题目:

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

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

思路:

本题属于斐波那契数列,思路如下:

// 1阶: 1种方法

// 2阶: 2种

// 3阶: 3种

// 4阶: 5种

// 5阶: 8种

// 你会发现一个规律,当前的n阶等于n-1和n-2的台阶方法数的总和

// 也就是f(n)=f(n-1)+f(n-2),这样把规律找出后,就可以编写了

p q r

0 0 1

0 1 1

1 1 2

1 2 3

2 3 5

cpp 复制代码
class Solution {
public:
    int climbStairs(int n) {
        int p=0,q=0,r=1;//p和q就代表着n-1和n-2,一开始初始化为0
        for(int i=1;i<=n;i++){
            p=q;
            q=r;
            r=p+q;
        }
        return r;
        // 1阶:1
        // 2阶:2
        // 3阶:3
        // 4阶:5
        // 5阶:8
        // 你会发现一个规律,当前的n等于n-1和n-2的台阶方法数的总和
        // 也就是f(n)=f(n-1)+f(n-2),这样把规律找出后,就可以编写了
    }
};
相关推荐
阿贵---1 分钟前
分布式系统C++实现
开发语言·c++·算法
不染尘.3 分钟前
最短路径之Bellman-Ford算法
开发语言·数据结构·c++·算法·图论
big_rabbit05026 分钟前
JVM堆内存查看命令
java·linux·算法
m0_662577978 分钟前
C++中的RAII技术深入
开发语言·c++·算法
旖-旎8 分钟前
二分查找(点名)(8)
c++·算法·二分查找·力扣
承渊政道11 分钟前
【优选算法】(实战体验滑动窗口的奇妙之旅)
c语言·c++·笔记·学习·算法·leetcode·visual studio
lemonth12 分钟前
图形推理----
人工智能·算法·机器学习
2401_8914821724 分钟前
C++代码复杂性分析
开发语言·c++·算法
keep intensify25 分钟前
单词搜索-
算法·深度优先
zx_zx_12325 分钟前
定长滑动窗口和不定长滑动窗口
数据结构·算法