记忆化递归之斐波那切数列

Posted guojbing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记忆化递归之斐波那切数列相关的知识,希望对你有一定的参考价值。

记忆化递归

  • 记忆化是一种保存前一个结果的值的优化技术,类似于缓存。
function fibonacciMemoization(n) {
    const memo = [0, 1, 1]

    if (n < 1) return 0
    if (n <= 2) return memo[n]

    const fibonacci = n => {
        if (memo[n]) { 
            return memo[n] 
        } else {
            if (!memo[n - 1]) { memo[n - 1] = fibonacci(n - 1) }
            if (!memo[n - 2]) { memo[n - 2] = fibonacci(n - 2) }
            memo[n] = memo[n - 1] + memo[n - 2]
            return memo[n]
        }
    }

    return fibonacci(n)
}

普通递归

function fibonacci(n) {
    if (n <= 0) return 0
    if (n < 2) return n

    return fibonacci(n - 1) + fibonacci(n - 2)
}

以上是关于记忆化递归之斐波那切数列的主要内容,如果未能解决你的问题,请参考以下文章

递归之斐波那契数列

递归之斐波那契数列

递归小程序之斐波那契数列

递归算法之斐波那契数列

JavaScript之斐波那契数列的几种实现方法兔子数列黄金分割数列递归for解构

README2动态规划之斐波那契数列说明重叠子问题如何解决