题目描述
8、一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
解题思路:
1、如果你看到题目不知道从哪下手,采用笨方法首先尽量罗列出来,计算f(1) = 1, f(2) = 2, f(3) = 3, f(4) = 5,这时你可能发现f(3) =f(1) + f(2), f(4) = f(2) + f(3), 那是不是总结出f(n) = f(n-1) + f(n-2)的规律,按这规律f(5) = 8,而自己在根据题目验证发现5级台阶确实是8种跳法。到此知道本题的本质就是类似斐波拉契数列的计算,只是将题目进行了改编,不容易让人识别判断出来。
2、本题分析:
1)、假设n个台阶时有f(n)种跳法,青蛙要么跳1个台阶要么跳2个台阶。
2)、假设第一次跳的是一阶,即后面剩余的n-1个台阶有f(n-1)种跳法。
3)、假设第一次跳的是二阶,即后面剩余的n-2个台阶有f(n-2 )种跳法。
4)、显然上n个台阶的总跳法等于前两种情况的跳法之和,即f(n) =f(n-1) + f(n-2)
5)、根据实际情况,1级台阶跳法:f(1) = 1;2级台阶跳法:f(2) = 2。
此题本质就是类斐波拉契数。反过来理解,第n级台阶只能从n-1或者n-2级台阶跳上来,也一样。
参考代码采用斐波拉契数的迭代实现,具体如下
参考代码:
/*************************************************
Copyright:牛客网在线编程《剑指offer》
Author:zhouyuan
Date:2017-02-27
Description:跳台阶
**************************************************/
class Solution {
public:
int jumpFloor(int number) {
if (number <= 0) {
return 0;
}
if (number == 1 || number == 2) {
return number;
}
int a = 1, b = 2, c;
while (number-- > 2) {
c = a + b;
a = b;
b = c;
}
return c;
}
};