算法-10.1斐波那契数列

2020-08-10  本文已影响0人  zzq_nene

斐波那契数列:0,1,1,2,3,5,8,13,21,34.....
即第n个为第n-2个+第n-1个

一、找出斐波那契数列的第n个数

递归实现和一般实现的时间复杂度为O(n)

1.递归实现

    public static int fibonacci(int n) {
        if (n == 0) {
            return 0;
        }
        if (n == 1 || n == 2) {
            return 1;
        }
        return fib1(n - 2) + fib1(n - 1);
    }

2.一般实现

    public static int fib2(int n) {
        if (n == 0) {
            return 0;
        }
        if (n == 1 || n == 2) {
            return 1;
        }
        int f1 = 1;
        int f2 = 1;
        int temp = 0;
        for (int i = 3; i <= n; i++) {
            temp = f1 + f2;
            f1 = f2;
            f2 = temp;
        }
        return temp;
    }

3.矩阵快速幂实现斐波那契数列

暂无

上一篇下一篇

猜你喜欢

热点阅读