一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。
1. 分析
跳到第n个台阶,只有两种可能
-
从第n-1个台阶跳1个台阶
-
从第n-2个台阶跳2个台阶
只需求出跳到第n-1个台阶和第n-2个台阶的可能跳法即可。定义F(n):n个台阶的跳法
递推公式:F(n)=F(n-1)+F(n-2)不难发现这是一个斐波那契数列。
解法:递归 和 动态规划;递归就不说了,因为栈会爆炸💥
动态规划:只保存两个变量,进行状态压缩,只记录有必要的数据。时间复杂度O(n),空间复杂度O(1)。
2. 用C++写出逻辑:
int Fibonacci(int n) {
if(n == 0) return 0;
if(n == 1) return 1;
if(n == 2) return 1;
int a = 1, b = 1;
int sum;
for(int i = 3; i <= n; i++){
sum = a + b;
a = b;
b = sum;
}
return sum;
}