forked from Ren0503/javascript-algorithms-and-data-structure
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrecursiveStaircaseMEM.js
43 lines (36 loc) · 1.46 KB
/
recursiveStaircaseMEM.js
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/**
* Bài Toán Đệ Quy Cầu Thang (Giải Pháp dùng Bộ Nhớ Phụ)
*
* @param {number} totalStairs - số bậc có thể bước.
* @return {number} - Số cách để bước lên cầu thang.
*/
export default function recursiveStaircaseMEM(totalStairs) {
// Bảng ghi nhớ sẽ chứa tất cả các kết quả được tính toán đệ quy để
// tránh tính toán chúng nhiều lần.
const memo = [];
// Đệ quy với closure.
const getSteps = (stairsNum) => {
if (stairsNum <= 0) {
// Số bậc nhỏ hơn 1 thì không có gì để bước
return 0;
}
if (stairsNum === 1) {
// Nếu chỉ có 1 bậc chỉ có một cách bước.
return 1;
}
if (stairsNum === 2) {
// Nếu có hai bậc có hai cách bước là (1+1) và (2).
return 2;
}
// Tránh đệ quy cho các bước đã tính toán gần đây.
if (memo[stairsNum]) {
return memo[stairsNum];
}
// Tính tổng số bước ta cần thực hiện sau khi thực hiện một bước
// với số bước ta cần thực hiện sau khi thực hiện hai bước lên.
memo[stairsNum] = getSteps(stairsNum - 1) + getSteps(stairsNum - 2);
return memo[stairsNum];
};
// Trả về các cách để có thể đi hết cầu thang.
return getSteps(totalStairs);
}