码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2020-07-26 00:18:08      阅读:73      评论:0      收藏:0      [点我收藏+]

标签:技术   code   class   ret   asc   记忆化   递归   ons   结果   

记忆化递归

  • 记忆化是一种保存前一个结果的值的优化技术,类似于缓存。
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)
}

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

标签:技术   code   class   ret   asc   记忆化   递归   ons   结果   

原文地址:https://www.cnblogs.com/guojbing/p/13376570.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!