In JavaScript, it’s commonly used for:
Join the software development bootcamp.
Instead of recalculating:
f(10) → compute again
f(10) → compute again
f(10) → compute again With memoization:
Join thousands already learning how to code online
f(10) → compute once
f(10) → return stored result
f(10) → return stored result function fib(n) {
if (n <= 1) return n;
return fib(n - 1) + fib(n - 2);
} This is slow because it recomputes the same values many times.
function memoizedFib() {
const cache = {}; // memory store
return function fib(n) {
if (n in cache) return cache[n]; // return saved result
if (n <= 1) return n;
const result = fib(n - 1) + fib(n - 2);
cache[n] = result; // save result
return result;
};
}
const fib = memoizedFib();
fib(40); // much faster
cache stores previous results.function memoize(fn) {
const cache = {};
return function (...args) {
const key = JSON.stringify(args);
if (cache[key]) {
return cache[key];
}
const result = fn(...args);
cache[key] = result;
return result;
};
} Usage:
const slowAdd = (a, b) => a + b;
const fastAdd = memoize(slowAdd);
fastAdd(3, 4); // calculated
fastAdd(3, 4); // from cache useMemo, useCallback)Memoization is caching function results so the same computation is never done twice.
Latest tech news and coding tips.
For years, responsive design has depended almost entirely on media queries. We ask questions like: “If…
1. What is Task Scheduling? Task scheduling is the process of automatically running commands, scripts,…
Here’s a comprehensive, clear differentiation between a Website and a Web App, from purpose all the…
Visual Studio Code (VS Code) is powerful out of the box, but its real strength…
1. What Is a Variable in JavaScript? A variable is a named container used to store data…
1. What Is a Queue? A Queue is a linear data structure that follows the principle: FIFO – First…