【动态规划】力扣509. FibonacciNumber-斐波那契数

斐波那契数
斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:
F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1
给你 n ,请计算 F(n) 。

五个步骤先放上面
1,确定dp数组(dp table)以及下标的含义
2,确定递推公式
3,dp数组如何初始化
4,确定遍历顺序
5,举例推导dp数组

1,
这题从一维数组来考虑比较好入手
首先根据动态规划的思维来分析这题
n是由n - 1和n - 2的情况来推导出来的
意思n可以由前面的数字慢慢推倒过来
那么就可以先求出1,2,3,4,5等等的情况来向后推倒
那么dp[i] 就是第i个数字的结果

2,
递推公式由递推关系求出来
递推关系已给
dp[i] = dp[i - 1] + dp[i - 2]

3,
初始化步骤
dp[0] 和 dp[1] 是最小基准,由他们俩就可以求出dp[2]的值,再慢慢向后推导
4,
首先i是到n的值,从最初的到最后
所以从左往右一个for循环

一维数组

class Solution {
    public int fib(int n) {
        int dp[] = new int[n + 1];
        dp[0] = 0;
        if(n >= 1) dp[1] = 1;
        for(int i = 2; i <= n; i++) dp[i] = dp[i - 1] + dp[i - 2];
        return dp[n];
    }
}

滚动数组
分析一下每次循环需要的东西
上一个情况和上上个情况
也就是我们只需要每次保存和更新上一次情况和上上次情况就行了

class Solution {
    public int fib(int n) {
        int first = 0, second = 1, third = (n == 0) ? 0 : 1;
        for(int i = 2; i <= n; i++) {
            third = first + second;
            first = second;
            second = third;
        }
        return third;
    }
}

你可能感兴趣的:(算法,#,动态规划/DP,动态规划,算法)