斐波那契数
题目链接:力扣题目链接
难度:简单
斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:
F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1
给定 n ,请计算 F(n) 。
示例 :
输入:n = 2
输出:1
解释:F(2) = F(1) + F(0) = 1 + 0 = 1
思路
动态规划五部曲:
定义一个一维dp数组来保存递归的结果。
1.确定dp数组以及下标的含义
dp[i]的定义:第i个数的斐波那契值为dp[i]
2.确定递推公式
状态转移方程 dp[i] = dp[i-1] + dp[i-2]
3.dp数组的初始化
题目中已经给出了 dp[0] = 0 , dp[1] = 1
4.确定遍历顺序
从递推公式中可以看出dp[i]是依赖dp[i-1] 和dp[i-2]的,所以遍历顺序肯定是从前到后的。
5.举例推导dp数组
如果代码写出来发现不对,把dp数组打印下来看看哪里出错了。
优化:只需要维护两个数值就可以了,不需要记录整个序列。
动态规划法
class Solution{
public int fib(int n) {
if(n == 0 || n == 1) return n;
int dp_0 = 0;
int dp_1 = 1;
int sum = 0;
for(int i = 2;i<=n;i++){
sum = dp_0 + dp_1;
dp_0 = dp_1;
dp_1 = sum;
}
return sum;
}
}
递归解法
class Solution{
public int fib(int n) {
if(n < 2){
return n;
}
return fib(n-1) + fib(n-2);
}
}