美文网首页
算法-10.1斐波那契数列

算法-10.1斐波那契数列

作者: zzq_nene | 来源:发表于2020-08-10 10:24 被阅读0次

斐波那契数列: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.矩阵快速幂实现斐波那契数列

暂无

相关文章

网友评论

      本文标题:算法-10.1斐波那契数列

      本文链接:https://www.haomeiwen.com/subject/bbxlrktx.html