You are on page 1of 19

Course : Data Structures

Subject Code : CSEN2001


Program : B. Tech
Year : II
Dept. and Sec : CSE ( )
UNIT : IV

Dr Kranthi Kumar Singamaneni


Dept. of C.S.E
G.S.T, GITAM Deemed to be University
Trees:

 Definitions and properties


 Representation of binary trees, operations
 Binary tree traversals
 Binary search tree
 AVL trees, operations
 Heap sort
An intuitive introduction to Non-Linear Data Structure
Suppose, John and Sarah are two high school students. Their class teacher assigned them to give a detailed list consisting of the names of
the Faculties in their year, along with their departments.
John decides to make a table consisting of the names of each person Sarah, on the other hand, decides to make a tree diagram that
along with his/her department and designations. shows all the faculties along with their designations:
Member Name Designation
Jane Principal
Marilla HOD, Science Dept
Anne Teacher, Physics
Gilbert Teacher, Chemistry
Moody Teacher, Math's
Mathew HOD, Commerce Dept
Jerry Teacher, Accountancy
Prissy Teacher, Business Studies
Mary Teacher, Economics

Q. Who do you think will get a better grade in their assessment?

It's Sarah because she has represented the relationship between the faculties while John has only provided a one-sided list that does
not show who works under whom. John's list is a linear data structure as you might have guessed, while Sarah's tree is a non-linear data
structure.
 A Non-Linear Data Structure is one in which its elements are not Q. Why is LinkedList Non-Linear?
connected in a linear fashion, as suggested by its name itself. Even though it might seem that LinkedList should be
 In such a data structure elements might be connected in a hierarchical Linear due to its sequential connection of elements, you
manner like a tree or graph, or it may be nonhierarchical like in a must remember that there is no contiguous memory
LinkedList. Non-linear data structures have a more complex structure in a LinkedList. All the elements of a LinkedList
implementation than their linear counterparts. are spread across the memory in a Non-Linear fashion,
hence it is a Non-Linear Data Structure.
 This session introduces Non-Linear Data structure, explores examples
of non-linear data structure, and goes through the differences Linear Data Structure Non-Linear Data Structure
between linear and nonlinear data structures. Elements are connected Elements are not
sequentially or in a connected sequentially or
 The main advantage of non-linear data structure is that it uses contiguous manner. in a contiguous manner.
memory very efficiently than linear data structures.
Elements are always Elements may be present in
present in a single level single or multiple levels.
Let us now analyze the key points of a Non-Linear Data Structure:
 Elements are not arranged sequentially. There is no hierarchy There is usually a hierarchy
between the elements. between elements.
 One element can be connected to multiple elements.
They are easier to They have a more complex
 There might be a hierarchical structure present. implement. implementation.
 Here, memory is not allocated in a contiguous manner, unlike Memory allocation is Memory allocation isn’t
linear data structure. sequential. sequential.
Can be traversed in a Requires multiple runs for
Examples of Non-Linear Data Structure: single run. traversal.
Inefficient utilization of Memory is utilized
Some examples of non-linear data structures are LinkedList, Trees, and memory. efficiently.
Graphs. We'll now go through each of them and understand why they are
Examples include arrays, Examples include trees,
called nonlinear data structures. hash tables, stack, queue graphs etc.
Tree: As you might have figured it, the tree is a data structure that is General Tree: A tree that can contain any number of subtrees is
both nonlinear as well as hierarchical. Here elements are arranged in known as a general tree.
multiple levels, and each level can be completely or partially filled. Let
us now go through some of the basic terminologies of a tree-

 Root – The topmost node of the tree


 Parent – Each node is a parent of the nodes connected to it, below.
 Child – Each node that is a descendant of another node is called a
child of that node.
 Siblings – Nodes with the same parent
 Leaf - The nodes in the last/bottom-most level of the tree
 Edge - Link connecting two nodes.
Binary Tree: A tree where each node has atmost two children
(known as left child and right child) is known as a binary tree.
In the figure below, each subtree has either one or two child.

We will now see the types of trees out there:


Binary Search Tree: A binary Search tree is a special kind of binary AVL Tree: AVL Tree is a special kind of Binary Search Tree where
tree that holds the following properties: the height difference of the left and right subtrees is less than or
equal to one. Eg - In the figure given below, let’s analyze height
 All the nodes in the left subtree hold key with a value lesser difference of the left and right subtrees for all the subtrees:
than the node's key value.
 All the nodes in the right subtree hold key with a value greater
than the node's key value.
 The first figure is a Binary Search Tree since it holds the above
two properties.

However, for the second figure, 2 lies in the right subtree of 3 and
has a lesser value than 3, whereas, in a Binary Search Tree, all the
nodes in the right subtree should hold a key with a value greater Parent Node Height of left Height of Height
than the node's key value. Hence, the second figure is not a Binary of Subtree subtree right subtree difference
Search Tree. 12 3 2 1
8 2 1 1
18 1 0 1
5 1 0 1
11 0 0 0
17 0 0 0
4 0 0 0

As, we can see, the maximum height difference between any left
and right subtree is one. Thus the below tree is an AVL Tree.
2-3 Tree: A tree where every non leaf node has either of the following B+ Tree: B+ tree is an extension of B Tree. It often contains large
two properties: number of children per node.
 One data element and two children.
 Two data elements and three children.

B Tree: A B Tree helps to store data in sorted order and is commonly


used in database or file systems. Below are some of the properties
that a B Tree of order m holds:
Red Black Tree: Red-black trees are self-balancing binary
 There can be atmost m children for each node.
search trees where each node has one extra attribute which
 There should be atleast ⌈m/2⌉ child nodes for each non-leaf node
denotes its color (either RED or BLACK). Nodes are colored to
(except root).
ensure that the height of the tree remains balanced after
 The root should contain minimum 1 key.
insertion or deletion from it.
 Depth of every leaf is same.
Types of binary trees
5. Skewed Binary Tree: A skewed binary tree
1. Full Binary Tree: A full Binary is a pathological/degenerate tree in which
tree is a special type of binary tree the tree is either dominated by the left nodes
in which every parent node/internal or the right nodes. Thus, there are two types
node has either two or no children. of skewed binary tree: left-skewed binary
tree and right-skewed binary tree.

2. Perfect Binary Tree: A perfect


binary tree is a type of binary tree 6. Balanced Binary Tree: It is a type of
in which every internal node has binary tree in which the difference between
exactly two child nodes and all the the height of the left and the right subtree
leaf nodes are at the same level. for each node is either 0 or 1.

3. Complete Binary Tree: It is a Binary Tree Representation: A node of a


special type of binary tree where binary tree is represented by a structure
all the levels of the tree are filled containing a data part and two pointers to
completely except the lowest level other structures of the same type.
nodes which are filled from as left
as possible.

4. Degenerate/Pathological Tree
A degenerate or pathological tree is
the tree having a single child either
left or right.
Representation of binary trees How to identify the left child, right child, and parent of any node that is
The Binary tree means the node can have a maximum of two represented in the sequential form?
children. Here, the binary name suggests that ‘two’; In instance 1
therefore, each node can have either 0, 1, or 2 children. A
binary tree data structure is represented using two methods.
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
Those methods are as follows...

1. Array Representation If a node is at the ith index the


2. Linked List Representation
• The left child would be at (2*i)+1
Consider the given binary tree... • The right child would be at (2*i+2)
• The parent would be the floor((i-1)/2)

1. Array Representation of Binary Tree In instance 2


In the array representation of a binary tree, we use a one-
dimensional array (1-D Array) to represent a binary tree.
Consider the above example of a binary tree, and it is 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
represented as follows...
If a node is at the ith index the

• The left child would be at (2*i)+


To represent a binary tree of depth 'n' using array
• The right child would be at (2*i+1)
representation, we need a one-dimensional array with a
maximum size of 2n + 1. • The parent would be the floor(i/2)
2. Linked List Representation of Binary Tree
Properties of Binary Tree
We use a double-linked list to represent a binary tree. In a •At each level of i, the maximum number of nodes is 2i.
double-linked list, every node consists of three fields. The first •The tree’s height is defined as the longest path from the root node
field is for storing the left child address, the second for storing to the leaf node. The tree which is shown above has a height equal to
actual data, and the third for storing the right child address. 3. Therefore, the maximum number of nodes at height 3 equals
(1+2+4) = 7.
In this linked list representation, a node has the following •Generally, the maximum number of nodes possible at height h is
structure... (20 + 21 + 22+….2h) = 2h+1 -1.
•The minimum number of nodes possible at height h equals h+1.
The general form of the left binary tree picture is represented If there are 'n' number of nodes in the binary tree.
using Linked list in the right-side picture. The minimum height can be computed as follows: As we know,
n = 2h+1 -1
n+1 = 2h+1
Taking logs on both sides,
log2(n+1) = log2 (2h+1)
log2(n+1) = h+1
h = log2 (n+1) - 1
The maximum height can be computed as: As we know,
n = h+1
h= n-1
Binary tree operations traversals 1. In-Order Traversal ( left child- root – right child)
The main operations in a binary tree are: search, insert and
In In-Order traversal, the root node is visited between the left child and
delete. When we wanted to display a binary tree, we need
the right child. In this traversal, the left child node is visited first, then
to follow some order in which all the nodes of that binary
the root node is visited, and later, we go for visiting the right child node.
tree must be displayed. In any binary tree, displaying order
This in-order traversal is applicable for every root node of all subtrees in
of nodes depends on the traversal method.
the tree. This is performed recursively for all nodes in the tree.
Displaying (or) visiting order of nodes in a binary tree is In the above example of a binary tree, first, we try to visit the left child
called as Binary Tree Traversal. of root node ‘A’, but A’s left child ‘B’ is a root node for the left subtree.
So we try to visit its (B’s) left child ‘D’, and again D is a root for subtree
There are three types of binary tree traversals. with nodes D, I, and J. So we try to visit its left child, 'I', and it is the
leftmost child. So first we visit 'I’ , then go for its root node 'D' and later
 In - Order Traversal we visit D's right child 'J'. With this, we have completed the left part of
 Pre - Order Traversal node B. Then visit 'B’, and next B's right child 'F' is visited. With this, we
 Post - Order Traversal have completed the left part of node A. Then visit root node 'A'. With
this, we have completed the left and root parts of node A. Then we go
Consider the following binary tree... for the right part of node A. In the right of A again, there is a subtree
with root C. So go for a left child of C, and again it is a subtree with root
G., But G does not have a left part, so we visit ’G’ and then visit G’s right
child K. With this, we have completed the left part of node C. Then visit
root node 'C' and next visit C's right child 'H' which is the rightmost
child in the tree. So we stop the process.

That means here we have visited in the order of I - D - J - B - F - A - G - K - C - H 


using In-Order Traversal
2. Pre - Order Traversal ( root – left child – right child )

In Pre-Order traversal, the root node is visited before the left child and right child nodes. In this traversal, the root node is visited first, then
its left child and later its right child. This pre-order traversal is applicable for every root node of all subtrees in the tree.

In the above example of a binary tree, first, we visit root node 'A' then visit its left child 'B' which is a root for D and F. So we visit B's left
child 'D’, and again D is a root for I and J. So we visit D’s left child, ’I’ which is the leftmost child. So next, we go to visit D’s right child ’J’.
With this, we have completed the root, left, and right parts of node D and the root, and left parts of node B. Next, visit B’s right child  ’F’.
With this, we have completed the root and left parts of node A.

So we go for A's right child 'C' which is a root node for G and H. After visiting C, we go for its left child 'G' which is a root for node K. So
next, we visit the left of G, but it does not have the left child, so we go for G’s right child, ’K’. With this, we have completed node C’s root
and left parts. Next, visit C's right child 'H' which is the rightmost child in the tree. So we stop the process.

That means here we have visited in the order of A-B-D-I-J-F-C-G-K-H using Pre-Order Traversal.

3. Post - Order Traversal ( left child – right child – root )

In Post-Order traversal, the root node is visited after the left child and right child. In this traversal, the left child node is visited first, then its
right child, and then its root node. This is recursively performed until the rightmost node is visited.

Here we have visited in the order of I - J - D - F - B - K - G - H - C - A using Post-Order Traversal.


C Binary Tree with an Example C Code (Search, Delete, Insert Nodes)
Binary tree is the data structure to maintain data into memory
of program. There exists many data structures, but they are
chosen for usage on the basis of time consumed in
insert/search/delete operations performed on data structures.

Binary tree is one of the data structures that are efficient in


insertion and searching operations. Binary tree works on O
(logN) for insert/search/delete operations.

Binary tree is basically tree in which each node can have two
child nodes and each child node can itself be a small binary
tree. To understand it, below is the example figure of binary
tree.

Binary tree works on the rule that child nodes which are lesser
than root node keep on the left side and child nodes which are
greater than root node keep on the right side. Same rule is
followed in child nodes as well that are itself sub-trees. Like in
above figure, nodes (2, 4, 6) are on left side of root node (9)
and nodes (12, 15, 17) are on right side of root node (9).
We will understand binary tree through its operations. We will cover following
operations.
• Create binary tree
• Search into binary tree
• Delete binary tree
• Displaying binary tree
Creation of binary tree: Binary tree is created by inserting root node and its
child nodes. We will use a C programming language for all the examples. Below is
the code snippet for insert function. It will insert nodes.

This function would determine the position as per value of node to be added and
new node would be added into binary tree. Function is explained in steps below
and code snippet lines are mapped to explanation steps given below.

[Lines 13-19] Check first if tree is empty, then insert node as root.
[Line 21] Check if node value to be inserted is lesser than root node value, then
• a. [Line 22] Call insert() function recursively while there is non-NULL left node
• b. [Lines 13-19] When reached to leftmost node as NULL, insert new node.
[Line 23] Check if node value to be inserted is greater than root node value, then
• a. [Line 24] Call insert() function recursively while there is non-NULL right node
• b. [Lines 13-19] When reached to rightmost node as NULL, insert new node.
Searching into binary tree: Searching is done as per value of node to
be searched whether it is root node or it lies in left or right sub-tree.
Below is the code snippet for search function. It will search node
into binary tree.

This search function would search for value of node whether node
of same value already exists in binary tree or not. If it is found, then
searched node is returned otherwise NULL (i.e. no node) is
returned. Function is explained in steps below and code snippet
lines are mapped to explanation steps given below.

1.[Lines 47-49] Check first if tree is empty, then return NULL.


2.[Lines 50-51] Check if node value to be searched is equal to root
node value, then return node
3.[Lines 52-53] Check if node value to be searched is lesser than
root node value, then call search() function recursively with left
node
4.[Lines 54-55] Check if node value to be searched is greater than
root node value, then call search() function recursively with right
node
5.Repeat step 2, 3, 4 for each recursion call of this search function
until node to be searched is found.
Deletion of binary tree: Binary tree is deleted by removing its child
nodes and root node. Below is the code snippet for deletion of binary
tree.

This function would delete all nodes of binary tree in the manner –
left node, right node and root node. Function is explained in steps
below and code snippet lines are mapped to explanation steps given
below.

[Line 39] Check first if root node is non-NULL, then


•a. [Line 40] Call deltree() function recursively while there is non-
NULL left node
•b. [Line 41] Call deltree() function recursively while there is non-
NULL right node
•c. [Line 42] Delete the node.
Displaying binary tree: Binary tree can be displayed in three forms – pre-order, in-
order and post-order.

•Pre-order displays root node, left node and then right node.
•In-order displays left node, root node and then right node.
•Post-order displays left node, right node and then root node.
These functions would display binary tree in pre-order, in-order and post-order
respectively. Function is explained in steps below and code snippet lines are mapped
to explanation steps given below.

Pre-order display

a. [Line 30] Display value of root node.


b. [Line 31] Call print_preorder() function recursively while there is non-NULL left node
c. [Line 32] Call print_preorder() function recursively while there is non-NULL right node

In-order display

a. [Line 37]Call print_inorder() function recursively while there is non-NULL left node
b. [Line38] Display value of root node.
c. [Line 39] Call print_inorder() function recursively while there is non-NULL right node

Post-order display

a. [Line 44] Call print_postorder() function recursively while there is non-NULL left node
b. [Line 45] Call print_postorder() function recursively while there is non-NULL right node
c. [Line46] Display value of root node.
Working program: It is noted that above code snippets are parts of below C program. This below program would be working basic program for binary tree.
#include<stdlib.h>#include<stdio.h> void print_preorder(node * tree) void deltree(node * tree)
struct bin_tree { {
{ if (tree) if (tree)
int data; { {
struct bin_tree * right, * left; printf("%d\n",tree->data); deltree(tree->left);
}; print_preorder(tree->left); deltree(tree->right);
typedef struct bin_tree node; print_preorder(tree->right); free(tree);
} }
void insert(node ** tree, int val) } }
{ node* search(node ** tree, int val)
node *temp = NULL; void print_inorder(node * tree) {
if(!(*tree)) { if(!(*tree))
{ if (tree) {
temp = (node *)malloc(sizeof(node)); { return NULL;
temp->left = temp->right = NULL; print_inorder(tree->left); }
temp->data = val; printf("%d\n",tree->data); if(val < (*tree)->data)
*tree = temp; return; print_inorder(tree->right); {
} } search(&((*tree)->left), val);
} }
if(val < (*tree)->data) else if(val > (*tree)->data)
{ void print_postorder(node * tree) {
insert(&(*tree)->left, val); { search(&((*tree)->right), val);
} if (tree) }
else if(val > (*tree)->data) { else if(val == (*tree)->data)
{ print_postorder(tree->left); {
insert(&(*tree)->right, val); print_postorder(tree->right); return *tree;
} printf("%d\n",tree->data); }
} } }
}
void main() Output of Program: It is noted that binary tree figure used at top of article can be
{ referred to under output of program and display of binary tree in pre-order, in-
node *root; node *tmp; root = NULL; order and post-order forms.

/* Inserting nodes into tree */


insert(&root, 9);
insert(&root, 4);
insert(&root, 15);
insert(&root, 6);
insert(&root, 12);
insert(&root, 17);
insert(&root, 2);

/* Printing nodes of tree */


printf("Pre Order Display\n");
print_preorder(root);
printf("In Order Display\n");
print_inorder(root);
printf("Post Order Display\n");
print_postorder(root);

/* Search node into tree */


tmp = search(&root, 4);
if (tmp)
{ printf("Searched node=%d\n", tmp->data); }
else
{ printf("Data Not found in tree.\n"); }

/* Deleting all nodes of tree */


deltree(root); }

You might also like