509. 斐波那契数

动态规划

class Solution {
    public int fib(int n) {

        /**
         * 因为n从0开始,初始了dp[0]和dp[1]
         * 为了避免dp[1]空指针异常,提前判断一下
         */    

        if (n < 1){
             return n;
         }

        int[] dp = new int[n + 1];

        dp[0] = 0;
        dp[1] = 1;

        for (int i = 2; i <= n; i++) {
            dp[i] = dp[i - 1] + dp[i - 2];
        }

        return dp[n];
    }
}

/**
 * 时间复杂度 O(n)
 * 空间复杂度 O(n)
 */

优化1——滚动数组减小空间复杂度

class Solution {
    public int fib(int n) {

        /**
         * 动态规划
         * fib(n)只与fib(n - 1)和fib(n - 2)有关,因此不需要存储所有的值,只用两个变量存储这两个值
         */
        if (n < 1){
            return n;
        }

        int[] dp = new int[3];
        dp[0] = 0;
        dp[1] = 1;
        dp[2] = 0;

        for (int i = 2; i <= n; i++) {

            dp[2] = dp[0] + dp[1];
            dp[0] = dp[1];
            dp[1] = dp[2];
        }

        return dp[1];
    }
}

/**
 * 时间复杂度 O(n)
 * 空间复杂度 O(1)
 */

注:不建议这么写,因为不能直观的表现出动态规划的思路!

https://leetcode-cn.com/problems/fibonacci-number/

posted @ 2022-01-18 13:59  振袖秋枫问红叶  阅读(23)  评论(0)    收藏  举报