A binary tree is a special kind of tree and important in computer science. There is plenty of real-world application of binary trees. The scope of this lesson is limited to the learning the binary tree concepts.
Informal definition
A tree is called a binary tree if it has the following properties.
- It is an empty tree with no nodes.
- The tree has a root node, left sub-tree and right sub-tree.
- The sub-trees are binary tree themselves.
Strictly Binary Tree
Suppose there is a binary tree with right sub-tree and left sub-tree. The sub-trees are in turn non-empty, then such a binary tree is called a strictly binary tree.
data:image/s3,"s3://crabby-images/a6e97/a6e97ec3c1d12acee98d694da4aa50270fd1f5cd" alt="Strictly Binary Tree - Binary Tree Concepts"
In the above figure, one is a strictly binary tree and the second tree is not a strictly binary tree, but it is certainly a binary tree and satisfy all the properties of a binary tree.
Complete Binary Tree
A complete binary tree has a level L and all its leaf nodes are available at level L. At each level the complete binary tree contains 2Lnodes.
Let us show this with an example,
data:image/s3,"s3://crabby-images/37e57/37e57369ead71ec24bbbe4e7a07037de7ea3fae1" alt="Complete Binary Tree - Binary Tree Concepts"
The root is at level 0, therefore, L = 0 and 2^L = 2^0 = 1.
Conversion of a Binary Forest into a Binary Tree
Suppose we have a forest with two trees as follows,
data:image/s3,"s3://crabby-images/18048/18048bc7fcfa79b9770c2a5dafffa79f1aabd99e" alt="Forest with Two Trees - binary tree concepts"
\begin{aligned} &T1 = { 1,2,3,4,5,6}\\ &T2 = { 7,8,9,10,11,12} \end{aligned}
The figure below show the two separate trees in the forest.
The first step is to order the nodes of both trees using following formula.
- If a node has left child, then if comes immediately below the node.
- If a node has another node in the save level, then it becomes the right child of the node.
- If a node has right child then, ignore it.
Such a representation of two trees is given below.
data:image/s3,"s3://crabby-images/c80f1/c80f15acb0ea706ecaea606033261f93e06cb542" alt="Forest with Two Ordered Trees - binary tree concepts"
Your next step should be to join these two tree into one by connecting their roots. This is because the roots of the trees are at the same level. See the figure below
data:image/s3,"s3://crabby-images/3fca0/3fca0b184a9b6eebc68747768a1240d99b0004bd" alt="Forest with Two Ordered Trees Joined - Binary tree concepts"
The new tree is a binary tree, the node at the save level in above diagram becomes the right child. The final tree structure look like the one in figure below.
data:image/s3,"s3://crabby-images/ec073/ec073a218f61d9dd383c2c70822cee3561aeeff2" alt="Final Joined Binary Tree - Binary Tree Concepts"
Total Number of Edges
In a complete binary tree, the total number of edges is given by the formula,
\begin{aligned} 2 (N_L - 1)\hspace{1ex} where \hspace{1ex}N_L\hspace{1ex} is \hspace{1ex}total\hspace{1ex} number \hspace{1ex}of\hspace{1ex} leaf \hspace{1ex}nodes. \end{aligned}
For example, see the tree below.
data:image/s3,"s3://crabby-images/72026/720263c5f4aac27045f3f3be37b94dfc657a63d0" alt="Complete Binary Tree with Edge Labelled -Binary Tree Concepts"
In the above diagram, we have .
Therefore,
\begin{aligned} &= 2( N_L - 1) \\ &= 2 ( 8 - 1) \\ &= 2 (7) \\ &= 14\hspace{1ex} edges. \end{aligned}
Height of a Binary Tree
The maximum level of any node of the binary tree is called the height of a binary tree.
For example, see the figure below.
data:image/s3,"s3://crabby-images/24638/24638e4e1332f7f661bbfa5689b71962854e6eb9" alt="Height Of The Tree - Binary Tree Concepts"
In the above tree figure, the maximum level of the tree is ,
Therefore, the height of the tree is .
References
R.G.Dromey. 2008. How to Solve it by Computer. Pearson Education India.
Robert Kruse, Cl Tondo. n.d. Data Structures and Program Design in C. Pearson Education India.
Thomas H. Cormen, Charles E. Leiserson, Ronald Rivest, Clifford Stein. 2009. Introduction to Algorithms. MIT Press.