JavaScript|斐波纳契数列

作者: 葶寳寳 | 来源:发表于2017-03-04 22:53 被阅读0次

斐波纳契数列定义:

斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=1,F(1)=1, F(n)=F(n-1)+F(n-2)(n>=2,n∈N*)

递归实现:

function fib(n) { 
    return n < 2 ? n : (fib(n - 1) + fib(n - 2)); 
}

<i>递归实现的难点在于对递归函数的理解</i>

非递归借助数组实现:

function fib(fibonacci) {
    return fibonacci[fibonacci.length - 1] + fibonacci[fibonacci.length - 2];
}

function main() {
    const n = document.getElementById("n").value;
    let fibonacci = [1, 1];
    for (let i = 0; i < n - 2; i++) {
        fibonacci.push(fib(fibonacci));
    }
    alert(fibonacci[fibonacci.length - 1]);
}

<i>n值较大时,数组会占用一定的内存空间</i>

非递归直接使用加法:

function fib(n) { 
  if (n < 2) { 
    return 1; 
  }  
  let a = 1, b = 1; 
  for (let i = 2; i < n - 1 ;i++ ) { 
    b = a + b; 
    a = b - a; 
  } 
  return a + b; 
}

<i>当n足够大时,建议使用直接加法</i>

如有错误,请指正,谢谢 ~

相关文章

  • 366. 斐波纳契数列

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

  • JavaScript|斐波纳契数列

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

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

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

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

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

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

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

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

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

  • 斐波那契数列

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

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

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

  • 有序表查找 - 斐波那契查找

    了解斐波那契查找之前先来了解下斐波那契额数列。 斐波那契数列,又称黄金分割数列,因数学家列昂纳多·斐波那契以兔子繁...

  • Python斐波拉契数列

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

网友评论

    本文标题:JavaScript|斐波纳契数列

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