news 2026/1/10 13:39:15

力扣70题 爬楼梯C++

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣70题 爬楼梯C++

【LeetCode 70】爬楼梯(C++)解题思路与代码实现

在LeetCode的算法题中,爬楼梯是一道经典的入门动态规划题目,其核心思想是通过递推关系找到问题的解。本文将详细讲解这道题的解题思路,并给出C++的实现代码,同时分析不同解法的优劣。

一、题目描述

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

提示: 1 <= n <= 45

示例:

- 输入: n = 2 ,输出: 2 (1阶+1阶、2阶)
- 输入: n = 3 ,输出: 3 (1+1+1、1+2、2+1)

二、解题思路

这道题的核心是找到递推公式,我们可以通过分析小规模的情况推导规律:

1. 当 n = 1 时,只有1种方法(爬1阶);
2. 当 n = 2 时,有2种方法(1+1、2);
3. 当 n = 3 时,到达第3阶的最后一步只能是从第2阶爬1阶,或从第1阶爬2阶,因此方法数为 f(2) + f(1) = 3 ;
4. 以此类推,对于第 n 阶,方法数 f(n) = f(n-1) + f(n-2) 。

这本质上是斐波那契数列的应用,只是初始条件略有不同(斐波那契数列通常以 f(0)=0, f(1)=1 开头,本题 f(1)=1, f(2)=2 )。

解法选择

- 递归:直接按递推公式递归,但会存在大量重复计算,时间复杂度为 O(2^n) ,当 n=45 时会超时;
- 动态规划(迭代):用变量保存中间结果,避免重复计算,时间复杂度 O(n) ,空间复杂度 O(1) ,是本题的最优解。

三、C++代码实现

这里采用迭代法实现,仅用三个变量保存中间值,空间复杂度优化至 O(1) :

cpp
class Solution {
public:
int climbStairs(int n) {
// 处理边界情况:n=1返回1,n=2返回2
if (n <= 2) {
return n;
}
// a表示f(n-2),b表示f(n-1),c表示f(n)
int a = 1, b = 2, c = 0;
// 从第3阶开始迭代计算到第n阶
for (int i = 3; i <= n; ++i) {
c = a + b; // 计算当前阶的方法数
a = b; // 递推:a变为下一次的f(n-2)
b = c; // 递推:b变为下一次的f(n-1)
}
return c;
}
};


代码解释

1. 边界处理:当 n≤2 时,直接返回 n ,因为这两种情况的方法数是确定的;
2. 变量初始化: a 初始为 f(1)=1 , b 初始为 f(2)=2 , c 用于存储当前阶的方法数;
3. 迭代计算:从第3阶开始,依次计算每一阶的方法数,通过递推更新 a 和 b ,最终 c 即为 f(n) 。

四、测试用例验证

我们可以通过几个测试用例验证代码的正确性:

1. 输入 n=1 ,输出 1 ,符合预期;
2. 输入 n=2 ,输出 2 ,符合预期;
3. 输入 n=3 ,输出 3 ,符合预期;
4. 输入 n=5 ,输出 8 (方法:1+1+1+1+1、1+1+1+2、1+1+2+1、1+2+1+1、2+1+1+1、1+2+2、2+1+2、2+2+1)。

五、总结

爬楼梯问题是动态规划的入门经典题,其核心是找到递推关系并通过迭代优化时间和空间复杂度。本题的迭代解法将时间复杂度控制在 O(n) ,空间复杂度优化至 O(1) ,能够高效处理题目给定的 n≤45 的范围。

对于这类递推型问题,我们需要先通过小规模案例推导规律,再选择合适的解法(递归/迭代/动态规划),同时注意优化重复计算和空间占用

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/6 7:33:33

GPT-5.2正式发布!国内首发“喂饭级”使用教程

近段时间&#xff0c;谷歌凭借Gemini 3赢得了一大批用户&#xff0c;称得上火力全开。12月11日&#xff0c;OpenAI也正式发布了新版本GPT-5.2&#xff0c;全力应对Gemini 3。虽然版本号只加了0.1&#xff0c;但GPT-5.2在多个实用领域&#xff08;干活能力&#xff09;更强了&am…

作者头像 李华
网站建设 2026/1/4 16:07:35

Caddy:把 HTTPS 变成默认选项的现代 Web 服务器

Caddy 是什么&#xff1f; Caddy 是一个现代化的 Web 服务器、反向代理和自动 HTTPS 平台。如果只用一句话来形容 —— Caddy 是“把 HTTPS 当成默认行为”的 Web 服务器。 和 Nginx、Apache 不同&#xff0c;Caddy 从诞生之初就围绕一个核心理念设计&#xff1a;安全应该是默…

作者头像 李华
网站建设 2026/1/8 13:15:35

Q-learning 算法 —— 无模型(model-free)强化学习

眼里没有对纪念日的专属感言&#xff0c;只有对优质文章诞生的渴望&#xff01;&#xff01;&#xff01; 一、研究背景与意义二、Q-learning 的核心思想1. 状态-动作价值函数&#xff08;Q 函数&#xff09;2. 核心创新点三、Q-learning 的更新公式&#xff08;核心公式&#…

作者头像 李华
网站建设 2026/1/6 18:05:05

如何避免过拟合?EmotiVoice在小样本下的鲁棒性设计

如何避免过拟合&#xff1f;EmotiVoice在小样本下的鲁棒性设计 在语音合成技术迅速普及的今天&#xff0c;我们早已不再满足于“能说话”的机器。用户期待的是有情感、有个性、像真人一样的声音——无论是虚拟助手温柔地安慰你&#xff0c;还是游戏角色愤怒地呐喊&#xff0c;背…

作者头像 李华
网站建设 2026/1/9 16:33:21

JavaScript 动态网页开发核心问题及实现页面动态更新方法

动态网页开发是现代Web应用的核心&#xff0c;而JavaScript是实现这一能力的关键语言。它不再是简单的页面装饰工具&#xff0c;而是驱动复杂交互、数据处理和实时内容更新的引擎。掌握JavaScript动态开发&#xff0c;意味着你能构建出响应迅速、体验流畅的现代网站。本文将避开…

作者头像 李华
网站建设 2026/1/9 12:25:11

Python中append()方法的使用、原理及效率解析

在Python编程中&#xff0c;列表的append()方法是一个基础且高频使用的操作&#xff0c;用于在列表末尾添加新元素。它看似简单&#xff0c;却直接影响着代码的效率与可读性。许多开发者因其便利性而过度依赖&#xff0c;却忽略了其背后的原理和潜在的性能陷阱。理解append()的…

作者头像 李华