在牛客网上做的:http://www.nowcoder.com/
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
递归问题,解法如下:
class Solution {
public:
int jumpFloor(int number) {
if(number==1) return 1;
else if(number==2) return 2;
else
return jumpFloor(number-1)+jumpFloor(number-2);
}
};
变态青蛙跳台阶
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
class Solution {
public:
int jumpFloorII(int number) {
int a[number+1];
for(int i=0;i<number+1;++i)
a[i]=0;
a[0]=-1,a[1]=1,a[2]=2;
for(int i=3;i<=number;i++){
for(int j=1;j<i;++j)
a[i] +=a[j];
a[i] +=1;
}
return a[number];
}
};