[Javascript] Memoization

时间:2020-09-17 16:31:51   收藏:0   阅读:32
const factorial = (n) => (n > 1 ? n * factorial(n - 1) : 1);

const memoize = (fn) => {
  const cache = {};
  return (...args) => {
    const key = JSON.stringify(args);
    return key in cache ? cache[key] : (cache[key] = fn.apply(null, args));
  };
};

const memoizedFactorial = memoize(factorial);

console.log(memoizedFactorial(9, { name: ‘Todd Motto‘ }));
console.log(memoizedFactorial(6));
console.log(memoizedFactorial(9, { name: ‘Todd Motto‘ }));

 

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!