题目描述
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?
注意:给定 n 是一个正整数。
递归解法
int helper(int n)
{
//if(n==0) return 0;
if(n==1) return 1;
if(n==2) return 2;
return helper(n-1)+helper(n-2);
}
时间复杂度过大,容易超时
自底向上解法
int climbStairs(int n)
{
if(n==1) return 1;
if(n==2) return 2;
int f1=1,f2=2,fn;
for(int i=2;i<n;i++)
{
fn=f1+f2;
f1=f2;
f2=fn;
}
return fn;
}