level order traversal of tree problems code example
Example: Level order traversal of binary tree
import collections
class TreeNode:
def __init__(self, val):
self.val = val
self.left = None
self.right = None
def levelOrderTraversal(root):
ans = []
if root is None:
return ans
queue = collections.deque()
queue.append(root)
while queue:
currSize = len(queue)
currList = []
while currSize > 0:
currNode = queue.popleft()
currList.append(currNode.val)
currSize -= 1
if currNode.left is not None:
queue.append(currNode.left)
if currNode.right is not None:
queue.append(currNode.right)
ans.append(currList)
return ans
root = TreeNode(1)
root.left = TreeNode(2)
root.right = TreeNode(3)
root.left.left = TreeNode(4)
root.left.right = TreeNode(5)
print(levelOrderTraversal(root))