美文网首页
LintCode:1807 · 斐波纳契数列

LintCode:1807 · 斐波纳契数列

作者: alex很累 | 来源:发表于2022-01-04 10:29 被阅读0次

问题描述

查找斐波纳契数列中第 N 个数。

所谓的斐波纳契数列是指:

  • 前2个数是 0 和 1 。
  • 第 i 个数是第 i-1 个数和第i-2 个数的和。
  • 斐波纳契数列的前10个数字是:0, 1, 1, 2, 3, 5, 8, 13, 21, 34 ...
  • N <= 20

样例

样例 1:
输入: 1
输出: 0
样例解释:返回斐波那契的第一个数字,是0.

样例 2:
输入: 2
输出: 1
样例解释: 返回斐波那契的第二个数字是1.

解题思路

根据题目描述,我们可以获得数列的通项公式:an=an-1+an-2;
简单的用递归/递推就能完成(在n非常大的情况下,递归会出现超时)。

代码示例(JAVA)

1. 递归

public class Solution {
    /**
     * @param n: an integer
     * @return: an ineger f(n)
     */
    public int fibonacci(int n) {
        if (n <= 2) {
            return n == 1 ? 0 : 1;
        }
        return fibonacci(n - 1) + fibonacci(n - 2);
    }
}

时间复杂度:O(2^n) 空间复杂度:O(n)
解释:
在求解fib(10)的时候,会找到fib(9)和fib(8)共两个,然后下一层会是fib(8)和fib(7),fib(7)和fib(6)共四个;这是一条底数为2呈指数增长的曲线。

2. 递推

public class Solution {
    /**
     * @param n: an integer
     * @return: an ineger f(n)
     */
    public int fibonacci(int n) {
        // write your code here
        int[] fib= new int[n];
        for (int i = 0; i < n; i++) {
            if (i <= 1) {
                fib[i] = i == 0 ? 0 : 1;
            }
            else {
                fib[i] = fib[i - 1] + fib[i - 2];
            }
        }
        
        return fib[n - 1];
    }
}

时间复杂度:O(n) 空间复杂度:O(n)
解释:
这里理解起来比较简单,不再赘述。对比递归算法,相当于加了一个缓存。
但是,空间复杂度可以再优化:可以从数列的通项公式看出,计算每个数时,只和前两个数有关,更前面的数已经不再使用了;因此,我们可以只使用长度为2的数组。

优化后代码如下:

public class Solution {
    /**
     * @param n: an integer
     * @return: an ineger f(n)
     */
    public int fibonacci(int n) {
        // write your code here
        int[] fib= {0, 1};
        for (int i = 2; i < n; i++) {
            fib[i % 2] = fib[0] + fib[1];
        }
        
        return fib[(n + 1) % 2];
    }
}

相关文章

  • LintCode:1807 · 斐波纳契数列

    问题描述 查找斐波纳契数列中第 N 个数。 所谓的斐波纳契数列是指: 前2个数是 0 和 1 。 第 i 个数是第...

  • 366. 斐波纳契数列

    查找斐波纳契数列中第 N 个数。所谓的斐波纳契数列是指: 斐波纳契数列的前10个数字是: 0, 1, 1, 2, ...

  • JavaScript|斐波纳契数列

    斐波纳契数列定义: 斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波...

  • [入门]366.斐波纳契数列

    我是小小强,这是我的第4篇原创文章,阅读需要大约10分钟。 题目 LintCode:斐波纳契数列 描述 查找斐波纳...

  • 我的python学习笔记-第八天

    先编个小程序 我们尝试来写一个斐波纳契数列。先说下啥是斐波纳契数列。事情是这样的:斐波那契数列(Fibonacci...

  • 尾递归优化的斐波那契数列

    斐波那契数列 斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(...

  • 递归优化的斐波那契数列

    斐波那契数列 斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(...

  • 斐波那契数,计算与分析

    什么是斐波那契数列? 斐波那契数列(Fibonacci sequence)是以意大利数学家列昂纳多·斐波那契的名字...

  • 斐波那契数列

    题目: 写一个函数,输入n,求斐波那契数列的第n项。 思路: 什么是斐波那契数列呢? 斐波纳契数列(Fibonac...

  • Python 斐波那契数列的几种实现

    先说下,什么是斐波那契数列? 斐波那契(Fibonacci)数列,又称黄金分割数列,因数学家列昂纳多·斐波那契(L...

网友评论

      本文标题:LintCode:1807 · 斐波纳契数列

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