You are climbing a stair case. It takes n steps to reach to the top.
Each time you can either climb 1 or 2 steps. In how many distinct ways can you climb to the top?
Note: Given n will be a positive integer.
int climbStairs(int n)
{
/*递归实现更好理解,但性能存在问题*/
if(n <= 0)
return 0;
if(1 == n)
return 1;
if(2 == n)
return 2;
int one_step_before = 2;
int two_steps_before = 1;
int all_ways = 0;
for(int i=2; i<n; i++)
{
all_ways = one_step_before + two_steps_before;
/*更改two_steps_before与one_step_before的值,计算下一个阶梯的ways*/
two_steps_before = one_step_before;
one_step_before = all_ways;
}
return all_ways;
}