-
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathindex.ts
55 lines (48 loc) · 1.14 KB
/
index.ts
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
44
45
46
47
48
49
50
51
52
53
54
55
import type { TreeNode } from '~/utils/treeNode'
/**
* 深度优先搜索
* @desc 时间复杂度 O(N) 空间复杂度 O(N)
* @param root
*/
export function sumNumbers(root: TreeNode | null): number {
let res = 0
root && dfs(root, root.val)
return res
function dfs(node: TreeNode, sum: number) {
if (!node.left && !node.right) {
res += sum
}
else {
node.left && dfs(node.left, sum * 10 + node.left.val)
node.right && dfs(node.right, sum * 10 + node.right.val)
}
}
}
/**
* 广度优先搜索
* @param root
*/
export function sumNumbers2(root: TreeNode | null): number {
if (!root) return 0
let sum = 0
const nodeQueue: TreeNode[] = [root]
const numQueue: number[] = [root.val]
while (nodeQueue.length) {
const node = nodeQueue.shift()!
const num = numQueue.shift()!
if (!node.left && !node.right) {
sum += num
}
else {
if (node.left) {
nodeQueue.push(node.left)
numQueue.push(num * 10 + node.left.val)
}
if (node.right) {
nodeQueue.push(node.right)
numQueue.push(num * 10 + node.right.val)
}
}
}
return sum
}