【问题标题】:Memoize a recursive Fibonacci function记忆递归斐波那契函数
【发布时间】:2021-11-17 15:29:32
【问题描述】:

我创建了一个withMemo 函数,它返回所提供函数的记忆版本。

const memoizedFn = withMemo(fn)

我怎样才能记住这个适用于递归的斐波那契函数?

const fibo = (n) => {

  if (n <= 1) return 1
  
  return fibo(n - 2) + fibo(n - 1)
}

确实withMemo(fibo) 并没有提高性能,因为fibo 内部的递归调用仍然指向未记忆的版本...

所以我必须更改 fibo 的声明以使 momoization 工作:

    const momoizableFibo = memoizer => {
      const fibo = (n) => {
    
        if (n <= 1) return 1
      
        return memoizer(fibo)(n - 2) + memoizer(fibo)(n - 1)
      }
      
      return memoizer(fibo)
    }
// momoizableFibo(withMemo)(50) // takes a ms 

有没有办法记住fibo(或任何其他递归函数)而不像我那样改变它的声明?

【问题讨论】:

  • 你检查过this吗?

标签: javascript algorithm recursion memoization


【解决方案1】:

您可以使用let fibo 代替const fibo。然后用记忆版本替换fibo 变量。通过更新fibo,嵌套调用现在将引用记忆化的fibo 函数而不是原始函数。

let fibo = (n) => {
  console.log(n); // <- show original fibo calls
  if (n <= 1) return 1;
  return fibo(n - 2) + fibo(n - 1);
}
// update fibo variable so the nested fibo call calls the memoized version
fibo = withMemo(fibo);

console.log("fibo(3)", "//=>", fibo(3));
console.log("fibo(5)", "//=>", fibo(5));
console.log("fibo(2)", "//=>", fibo(2));


// simplified memoize function, only works for serializable parameters
function withMemo(fn) {
  const cache = new Map();
  return function (...args) {
    const key = JSON.stringify(args);
    if (cache.has(key)) return cache.get(key);
    const result = fn(...args);
    cache.set(key, result);
    return result;
  }
}

【讨论】:

  • fibo = memo(fibo);太明显了 让我很尴尬
猜你喜欢
  • 2011-12-14
  • 2020-03-02
  • 1970-01-01
  • 1970-01-01
  • 2021-05-21
  • 1970-01-01
  • 2021-12-01
  • 2020-07-17
  • 2010-12-03
相关资源
最近更新 更多