题目:假设你正在爬楼梯,需要n步你才能到达顶部。但每次你只能爬一步或者两步,你能有多少种不同的方法爬到楼顶部?
思路:当阶梯数n为1或者2时,步数等于阶梯数;步数为(i-1)的步数与(i-2)的步数和。
class Solution {
public:
/**
* @param n: An integer
* @return: An integer
*/
int climbStairs(int n) {
// write your code here
int i,s[n];
if(n==0)
return 1;
s[0]=1;
if(n>=1)
{
s[1]=2;
for(i=2;i<n;i++)
{
s[i]=s[i-1]+s[i-2];
}
return s[n-1];
}
}
};
};
截图: