509. 斐波那契数

动态规划

class Solution {
    public int fib(int n) {

        /**
         * 动态规划
         */
         if (n < 2){
             return n;
         }
         
        int[] value = new int[n + 1];

        value[0] = 0;
        value[1] = 1;

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

        return value[n];
    }
}

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

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

class Solution {
    public int fib(int n) {

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

        int a = 0;
        int b = 0;
        int c = 1;

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

            a = b;
            b = c;
            c = a + b;
        }

        return c;
    }
}

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

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

上一篇:DELPHI XE BPL整合成一个包


下一篇:2021-ICPC-济南 Strange Series