103. Binary Tree Zipzag Level Order Traversal

Given a binary tree, return thezigzag level ordertraversal of its nodes' values. (ie, from left to right, then right to left for the next level and alternate between).

For example: Given binary tree[3,9,20,null,null,15,7],

    3
   / \
  9  20
    /  \
   15   7

return its zigzag level order traversal as:

[
  [3],
  [20,9],
  [15,7]
]

Thoughts:

  1. order to expanding which node's child in the current level -> using stack<TreeNode*> to reverse the order.

  2. for each Node in the current level, decide weather to first push left or right into the queue:

    1. curDepth is odd -> next level even -> Normal Order

    2. curDepth is even -> next level odd -> reverse Order

Code

Code (Python)

Special Thanks fangkunjnsy for the reference

Last updated

Was this helpful?