-
-
Notifications
You must be signed in to change notification settings - Fork 100
/
Copy pathbinary-tree-zigzag-level-order-traversal.js
66 lines (65 loc) · 1.9 KB
/
binary-tree-zigzag-level-order-traversal.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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {TreeNode} root
* @return {number[][]}
*/
// BFS广度思路:
// x y 左右节点push到stack中
// 1 2 3 4
// 从头拿出来 左边就push 把后面的放到后面, 右边是unshift把后面的插入到前面
// var zigzagLevelOrder = function (root) {
// if (!root) return []
// let type = 'left'
// let stack = [root]
// let res = []
// while (stack.length) {
// let len = stack.length
// let levelList = []; // 层级
// while (len) {
// let node = stack.shift() // 从头取出来
// // 左边就push 把后面的放到后面, 右边是unshift把后面的插入到前面
// if (type === 'left') {
// levelList.push(node.val)
// } else {
// levelList.unshift(node.val)
// }
// // 左右节点直接添加即可
// if (node.left) stack.push(node.left)
// if (node.right) stack.push(node.right)
// len--
// }
// type = type === 'left' ? 'right' : 'left' // 更改方向
// res.push(levelList) // 添加层级
// }
// return res
// };
// BFS 深度思路:
// deep深度来判断层级 来判断往前还是往后添加
var zigzagLevelOrder = function (root) {
if (!root) return []
let res = []
const BFSHelp = (node, deep) => {
if (!node) return
// 初始化层级
if (!res[deep]) {
res[deep] = []
}
if (deep % 2 === 0) {
// 双数 往左 从左开始 把后面的放在后面
res[deep].push(node.val)
} else {
// 单数 往右 从左开始 把后面的放在前面
res[deep].unshift(node.val)
}
BFSHelp(node.left, deep + 1)
BFSHelp(node.right, deep + 1)
}
BFSHelp(root, 0)
return res
}