Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Memoized Factorial
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36
Browser:
Chrome 124
Operating system:
Windows
Device Platform:
Desktop
Date tested:
2 years ago
Test name
Executions per second
Factorial memoized
74246.6 Ops/sec
Factorial plain
11584203.0 Ops/sec
Script Preparation code:
const memoize = fn => { const cache = {}; return (...args) => { argStr = JSON.stringify(args); cache[argStr] = cache[argStr] || fn(args); return cache[argStr]; } } const factorial = memoize((n) => { if (n <= 1) return 1; return n * factorial(n - 1); })
Tests:
Factorial memoized
const memoize = fn => { const cache = {}; return (...args) => { argStr = JSON.stringify(args); cache[argStr] = cache[argStr] || fn(args); return cache[argStr]; } } const factorial = memoize((n) => { if (n <= 1) return 1; return n * factorial(n - 1); }); factorial(10);
Factorial plain
const factorial =(n) => { if (n <= 1) return 1; return n * factorial(n - 1); }; factorial(10)