This post is completed by 2 users
|
Add to List |
75. Print the Binary Tree in Vertical Order Path
Objective: - Given a binary tree, print it in vertical order path.
What is Vertical Order
data:image/s3,"s3://crabby-images/7007c/7007ce5bb8a6e23a3a197e36cf751442a3f834b9" alt=""
as you can see in the example above, [4],[2], [1,5,6],[3],[7] are the vertical order of the given binary tree.
Approach:
- Do the preorder traversal.
- Take a variable called level, whenever you go left, do level++ AND whenever you go right do level--.
- With the step above we have separated the levels vertically.
- Now you need to store the elements of each level, so create a map or dictionary to store the level as key and elements at that level as value.
- At the end iterate through the dictionary and print the results.
data:image/s3,"s3://crabby-images/eea81/eea81fb962a6164bf6d9f040a1e991046c84d1b2" alt="Separate out the vertical levels"
Output:
[4] [2] [1, 5, 6] [3] [7]