# 2623. 记忆函数
# 题目
请你编写一个函数,它接收另一个函数作为输入,并返回该函数的 记忆化 后的结果。
记忆函数 是一个对于相同的输入永远不会被调用两次的函数。相反,它将返回一个缓存值。
你可以假设有 3 个可能的输入函数:sum 、fib 和 factorial 。
sum 接收两个整型参数 a 和 b ,并返回 a + b 。 fib 接收一个整型参数 n ,如果 n <= 1 则返回 1,否则返回 fib (n - 1) + fib (n - 2)。 factorial 接收一个整型参数 n ,如果 n <= 1 则返回 1 ,否则返回 factorial(n - 1) * n 。
示例 1:
输入: "sum" ["call","call","getCallCount","call","getCallCount"] [[2,2],[2,2],[],[1,2],[]] 输出: [4,4,1,3,2] 解释: const sum = (a, b) => a + b; const memoizedSum = memoize(sum); memoizedSum (2, 2);// 返回 4。sum() 被调用,因为之前没有使用参数 (2, 2) 调用过。 memoizedSum (2, 2);// 返回 4。没有调用 sum(),因为前面有相同的输入。 //总调用数: 1 memoizedSum(1、2);// 返回 3。sum() 被调用,因为之前没有使用参数 (1, 2) 调用过。 //总调用数: 2成功
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
示例 2:
输入: "factorial" ["call","call","call","getCallCount","call","getCallCount"] [[2],[3],[2],[],[3],[]] 输出: [2,6,2,2,6,2] 解释: const factorial = (n) => (n <= 1) ? 1 : (n * factorial(n - 1)); const memoFactorial = memoize(factorial); memoFactorial(2); // 返回 2。 memoFactorial(3); // 返回 6。 memoFactorial(2); // 返回 2。 没有调用 factorial(),因为前面有相同的输入。 // 总调用数:2 memoFactorial(3); // 返回 6。 没有调用 factorial(),因为前面有相同的输入。 // 总调用数:2成功
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
示例 3:
输入: "fib" ["call","getCallCount"] [[5],[]] 输出: [8,1] 解释: fib(5) = 8 // 总调用数:1成功
1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
提示:
- 0 <= a, b <= 105
- 1 <= n <= 10
- 最多105个函数调用
- 最多105次尝试访问callCount
- 输入函数是sum, fib或factorial
# 答案
/** * @param {Function} fn */ function memoize(fn) { const memory = new Map(); return function(...args) { const argsStr = JSON.stringify(args); if(memory.has(argsStr)) { return memory.get(argsStr); } else { const res = fn && fn(...args); memory.set(argsStr, res); return res; } } } /** * let callCount = 0; * const memoizedFn = memoize(function (a, b) { * callCount += 1; * return a + b; * }) * memoizedFn(2, 3) // 5 * memoizedFn(2, 3) // 5 * console.log(callCount) // 1 */成功
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# 思路
利用Map做缓存,调用函数时读取缓存数据