美文网首页
算法-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