103. Binary Tree Zigzag Level Order Traversal
Leetcode
題目
Input: root = [3,9,20,null,null,15,7]
Output: [[3],[20,9],[15,7]]Input: root = [1]
Output: [[1]]Input: root = []
Output: []解答
Last updated
Input: root = [3,9,20,null,null,15,7]
Output: [[3],[20,9],[15,7]]Input: root = [1]
Output: [[1]]Input: root = []
Output: []Last updated
var zigzagLevelOrder = function(root) {
if(!root) return [];
let queue = [root];
let height = 1;
const res = [];
while(queue.length) {
const isOddLevel = height % 2 === 1;
const values = queue.map(q => q.val);
// 如果是奇數層的話,代表要把數值從左向右加入
// 如果是偶數層的話,代表要把數值從右向左加入
isOddLevel ? res.push(values) : res.push(values.reverse());
const len = queue.length;
// 全部節點都由左至右順向加入
for(let i=0; i<len; i++) {
const node = queue.shift();
if(node.left) queue.push(node.left);
if(node.right) queue.push(node.right);
}
height++;
}
return res;
};var zigzagLevelOrder = function(root) {
if (!root) return [];
const res = [];
let levelList = [];
const queue = [root, null];
let isOrderLeft = true;
while(queue.length) {
const node = queue.shift();
if (node) {
if(isOrderLeft) {
levelList.push(node.val);
} else {
levelList.unshift(node.val);
}
if(node.left) queue.push(node.left);
if(node.right) queue.push(node.right);
} else {
res.push(levelList);
levelList = [];
if(queue.length) {
// add null as delimiter
queue.push(null);
}
isOrderLeft = !isOrderLeft;
}
}
return res;
};var zigzagLevelOrder = function(root) {
const res = [];
const dfs = (node, level) => {
if (!node) return;
const isLeftOrder = level % 2 === 0;
if (res[level]) {
if(isLeftOrder) {
// 由左往右加入元素
res[level].push(node.val);
} else {
// 由右往左加入元素
res[level].unshift(node.val);
}
} else {
res[level] = [node.val];
}
dfs(node.left, level + 1);
dfs(node.right, level + 1);
}
dfs(root, 0);
return res;
};