假设你正在爬楼梯。需要 n 步你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
注意:给定 n 是一个正整数。
示例 1:
输入: 2 输出: 2 解释: 有两种方法可以爬到楼顶。 1. 1 步 + 1 步 2. 2 步
示例 2:
输入: 3 输出: 3 解释: 有三种方法可以爬到楼顶。 1. 1 步 + 1 步 + 1 步 2. 1 步 + 2 步 3. 2 步 + 1 步
一看到这道题我们就会条件反射般想到递归,不就是斐波那契数列递归函数吗。一敲,喔嚯,超时了。这时我们就要思考更简单的解法。既然是数列,我们把数列的对应项都填进数组,直接返回数组的对应项岂不美哉??完全避免了递归函数冗长的缺点!!
class Solution {
public:
int climbStairs(int n) {
int a[90];
a[0]=1;
a[1]=1;
for(int i=2;i<=89;i++){
a[i]=a[i-1]+a[i-2];
}
return a[n];
}
};