What is the top view of a binary tree?
The Binary tree concept is touted among the most essential concepts including arrays, strings, longest substring without repeating characters and several other concepts that you are rooting to prepare for the upcoming coding interview.
This single concept is so comprehensive that a wide variety of questions can be formed out of it.
One such concept that we are going to discuss in this tutorial is the top view of a binary tree!
The top view in a binary tree is touted to have all the nodes that gets visible when we will see the tree from the top to the bottom of all the nodes.
To print the top view of a given binary, you first need to print nodes in any order.
Well, there are many more technicalities attached to the concept of top view of binary tree.
If you are ready to learn everything about it in-depth, stay with us till the end of this blog post.
Let’s get started!
Binary tree – A Glimpse
Binary tree is defined as a tree with structure of certain nodes that are connected to each other. Each node will have a maximum of two children which are called as the lefty or the right child.
Top view of a binary tree
The top view of a given binary tree consists of all the sets of nodes that are mainly visible when the tree gets offered from the top. A binary tree is given to us and we have to print it from the top.
The output nodes in any case can be printed by starting from its left horizontal level towards the right horizontal level of a binary tree.
In this blog , we are going to get a glimpse of the set of nodes which are basically visible when you view a binary tree from the top. You may not need to bother about the order of any node in your binary tree that needs to be printed.
Consider the problem statement
A binary tree is given. Print all the required nodes that are visible from the top of a binary tree. Nodes need to be printed in any order that starts from the left horizontal level to the right horizontal node level.
Take an example
1
↙ ↘
2 3
↙ ↘ ↙ ↘
4 5 1 7
↙ ↘
8 9
Top view in this case would be 4, 2, 1, 3 and 7
Solutions to follow
Let’s discuss the solutions that you will get in case of the top view of a binary tree. The depth-first search inorder traversal and breadth-first search inorder traversal would be followed in this case.
Depth-first search inorder traversal
The idea to use in this approach would be to perform a given in-order traversal for the binary tree. In this case, the top view of your binary tree contains all those nodes which consist of several distinct values which are either of the vertical or horizontal width or may contain both of them.
In the case of multiple nodes that are having the same value of horizontal width or the vertical length, you may use hashing in order to see if the node has a current node which needs to be traversed at the initial.
Comider a tree that will have eight vertices. Consider [ 0,0] as its vertical height and the horizontal width of a particular node as suggested.
Steps to follow:
- We can start from vertex 1 till the vertex 2 as in the order of traversal of your binary tree as we can get the current vertex
- We can move from the vertex 2 till the vertex 4 as i the order of traversal of the vertex 2 which will have no left child , so we can add to the current vertex
- We can traverse from the vertex 4 till vertex 6 where in the order of traversal of a binary tree with the vertex 4 having no child
- Move to the vertex 6 which would be the vertex 7 as the order of traversal with vertex 6 having no child
- Move to root of vertex 1 and after reaching there, we will find that height of vertex 1 would be smaller than the corresponding vertex height
- Move to right of vertex 1 which is vertex 3 where we will find the height of current node
- Now we can move to the right of a given vertex 3 which can be vertex 5 and after reaching there, find the current node’s height with the same horizontal width.
Breadth First Search In-order Traversal
The idea here is to perform the breadth first search traversal. Whenever, we will be performing this traversal, any particular tree level gets traversed before reaching the horizontal levels.
In this case, we will not keep track of all the heights or nodes of a binary tree. In other words, we can simply track the given horizontal or vertical width with the tree nodes.
In order to perform the breadth first search traversal, we need to check the given horizontal width to see if the nodes have yet been visited or not. With this, we would be able to map the horizontal level of a current node.
Here, we will also consider the eight vertices of the binary tree and perform the breadth first search traversal so as to store the maps into the required tree maps.
As we are using this traversal to find the top view, the time complexity of this tree would be the O[N] that will store all the nodes in a tree that is required to use as a map in the queues of DFS.
Wrapping Up
From binary trees to arrays to strings to longest substring without repeating characters, we can learn several essential coding concepts.
In this blog, we discussed in detail about the top view of a binary tree. Learn the knits and grits on this subject and excel at your interview.