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

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)
}

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