KEMBAR78
Trees | PDF | Algorithms And Data Structures
0% found this document useful (0 votes)
43 views78 pages

Trees

The document provides a comprehensive overview of tree data structures, including definitions, terminologies, types of trees (such as binary, ternary, and AVL trees), and their properties. It discusses various tree traversal techniques, representation methods, and the differences between threaded and unthreaded binary trees. Additionally, it covers binary search trees, their construction, deletion methods, and balancing techniques for AVL trees.

Uploaded by

mannuverma83040
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
43 views78 pages

Trees

The document provides a comprehensive overview of tree data structures, including definitions, terminologies, types of trees (such as binary, ternary, and AVL trees), and their properties. It discusses various tree traversal techniques, representation methods, and the differences between threaded and unthreaded binary trees. Additionally, it covers binary search trees, their construction, deletion methods, and balancing techniques for AVL trees.

Uploaded by

mannuverma83040
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 78

Tree Data Structure

By: Pritesh Saklecha

CS_GATE@PRITESH_SAKLECHA 1
Tree
• Non primitive Non Linear data structure.
• It is use to represent hierarchical relationship between the data
items.
• Mathematical defination : Acyclic connected graph is called tree.
• Tree with n nodes having n-1 edges.

CS_GATE@PRITESH_SAKLECHA 2
Tree terminologies :
1. Root
2. Parent node
3. Child node
4. Left sub-tree
5. Right sub-tree
6. Leaf node(external node)
7. Non leaf node(internal node)
8. Siblings
9. Level
10. Height
11. Left child
12. Right child
13. Path
14. Degree of node
15. Degree of tree

CS_GATE@PRITESH_SAKLECHA 3
• Types of tree:
• Binary Tree
• Strict binary tree/full binary tree
• Complete binary tree
• Perfect binary Tree
• Degenerate Tree
• Ternary Tree
• N-ary Tree

Binary Tree : A node can have maximum two child. So


maximum degree of any node is 2 and minimum degree is 0.

CS_GATE@PRITESH_SAKLECHA 4
Full Binary Tree A Binary Tree is a full binary tree if every node has 0 or 2
children. The following are the examples of a full binary tree. We can also say a
full binary tree is a binary tree in which all nodes except leaf nodes have two
children.

CS_GATE@PRITESH_SAKLECHA 5
Complete Binary Tree: A Binary Tree is a complete Binary Tree if all the
levels are completely filled except possibly the last level and the last
level has all keys as left as possible.

CS_GATE@PRITESH_SAKLECHA 6
Perfect Binary Tree A Binary tree is a Perfect Binary Tree in which all the
internal nodes have two children and all leaf nodes are at the same level

CS_GATE@PRITESH_SAKLECHA 7
A degenerate tree A Tree where every internal node has one child. Such trees
are performance-wise same as linked list.

CS_GATE@PRITESH_SAKLECHA 8
IMP points :
1. The minimum number of nodes in Binary tree is h+1 and maximum number
of nodes 2h+1 – 1.
2. Number of nodes in full binary tree is 2*leaf node -1.
3. In Full/Perfect binary tree : (assume root node at height =0)
1. The number of nodes are 2h+1 – 1.
2. The number of internal nodes are 2h – 1.
3. The number of external nodes are 2h .
4. Number of internal node = number of leaf node -1

CS_GATE@PRITESH_SAKLECHA 9
Representation of binary tree :
1. Using Array
2. Using Link list

a b c g e f h
0 1 2 3 4 5 6
To store complete or perfect binary tree of size n we need array of maxsize.

CS_GATE@PRITESH_SAKLECHA 10
Link list representation:

struct treenode
{ lchild info rchild
int info;
struct node *lchild;
struct node *rchild;
}*start;
typedef struct treenode N;

CS_GATE@PRITESH_SAKLECHA 11
Tree Traversal technique :
N

L R

CS_GATE@PRITESH_SAKLECHA 12
Tree Traversal techniques:

1. Inorder

2. Preorder

3. Postorder

4. Converse inorder

5. Converse preorder

6. Converse Postorder

7. Inverse inorder

8. Inverse preorder

9. Inverse postorder

CS_GATE@PRITESH_SAKLECHA 13
Q. Write functions to implement recursive versions of preorder, inorder and postorder
traversals of a binary tree.

CS_GATE@PRITESH_SAKLECHA 14
1. Inorder : (Left Root Right)

void inorder(node *tree)


{
if (tree != null)
then
inorder(treelchild);
print “treedata”;
inorder (treerchild);
}

CS_GATE@PRITESH_SAKLECHA 15
2. Preorder : (Root Left Right)

void preorder(node *tree)


{
if (tree != null)
then
print “treedata”;
preorder(treelchild);
preorder (treerchild);
}

CS_GATE@PRITESH_SAKLECHA 16
2. Postorder : (Left Right Root)

void preorder(node *tree)


{
if (tree != null)
then
postorder(treelchild);
postorder(treerchild);
print “treedata”;
}

CS_GATE@PRITESH_SAKLECHA 17
Tree Traversal?
A

B C

D E

F G

CS_GATE@PRITESH_SAKLECHA 18
Tree Traversal?

CS_GATE@PRITESH_SAKLECHA 19
Tree Traversal?

CS_GATE@PRITESH_SAKLECHA 20
Tree Traversal?

CS_GATE@PRITESH_SAKLECHA 21
Q. The in-order and pre-order traversal sequence of a node in a binary tree are given below:
In-order: EACKFHDBG
Pre-order: FAEKCDHGB
Draw the binary tree. State briefly the logic used to construct the tree.

CS_GATE@PRITESH_SAKLECHA 22
Q.Is there any difference between threaded and unthreaded binary tree? What is a B-tree?
Explain.

CS_GATE@PRITESH_SAKLECHA 23
Design Expression tree for the following and then find pre,post and inorder of
resultant tree.

1. a+(b+c*d+e)+f/g
2. a-b/(c-d-e)*e*f^g^h
3. (a+b)/(c+d)
4. a+b*c^d^e-f

CS_GATE@PRITESH_SAKLECHA 24
Design Expression tree for the following and then find pre,post and inorder of
resultant tree.

1. a+(b+c*d+e)+f/g
2. a-b/(c-d-e)*e*f^g^h
3. (a+b)/(c+d)
4. a+b*c^d^e-f

CS_GATE@PRITESH_SAKLECHA 25
Design Expression tree for the following and then find pre,post and inorder of
resultant tree.

1. a+(b+c*d+e)+f/g
2. a-b/(c-d-e)*e*f^g^h
3. (a+b)/(c+d)
4. a+b*c^d^e-f

CS_GATE@PRITESH_SAKLECHA 26
Design Expression tree for the following and then find pre,post and inorder of
resultant tree.

1. a+(b+c*d+e)+f/g
2. a-b/(c-d-e)*e*f^g^h
3. (a+b)/(c+d)
4. a+b*c^d^e-f

CS_GATE@PRITESH_SAKLECHA 27
Q. Explain traversal binary tree and threaded binary tree.

CS_GATE@PRITESH_SAKLECHA 28
Threaded Binary Tree
A threaded binary tree is a special type of binary tree that makes traversal more efficient by
using pointers called "threads" to connect nodes without requiring recursion or a stack.

Why Use Threaded Binary Trees?


•Traditional tree traversal (inorder, preorder, postorder) uses recursion or stacks, increasing
space complexity.
•A threaded binary tree replaces null pointers with references (threads) to the next logical node
in traversal order, allowing faster traversal without extra space.

CS_GATE@PRITESH_SAKLECHA 29
Differences Between Threaded and Unthreaded Binary Trees:
1.Threaded Binary Tree
1. Uses threads in place of null child pointers.
2. Enables faster inorder traversal without recursion or a stack.
3. Can be single-threaded (only successor or predecessor threads) or double-threaded
(both successor and predecessor threads).
2.Unthreaded (Traditional) Binary Tree
1. Uses null pointers in the absence of a left or right child.
2. Requires recursion or a stack for inorder traversal.
3. More common in standard tree implementations.

CS_GATE@PRITESH_SAKLECHA 30
Binary Search Tree: K

Less greater
than K than K

Generally equal keys are not used in BST. But if given in question then they may
be added in left or right of root depends on the situation given in question.

CS_GATE@PRITESH_SAKLECHA 31
Q1. Design BST and find inorder traversal of resultant tree?
(a) 3, 5, 11, 8, 4 , 1 , 12, 7 , 2 , 6, 10
(b) 1, 2, 3, 4, 5, 6, 7
(c) 7, 6, 5, 4, 3, 2, 1
(d) S, T, P, Q, M, N, O, R, K, V, A, B.
Q2. How many different binary search tree possible for keys 1,2,3.?

CS_GATE@PRITESH_SAKLECHA 32
Q1. Design BST and find inorder traversal of resultant tree?
(a) 3, 5, 11, 8, 4 , 1 , 12, 7 , 2 , 6, 10
(b) 1, 2, 3, 4, 5, 6, 7
(c) 7, 6, 5, 4, 3, 2, 1
(d) S, T, P, Q, M, N, O, R, K, V, A, B.
Q2. How many different binary search tree possible for keys 1,2,3.?

CS_GATE@PRITESH_SAKLECHA 33
CS_GATE@PRITESH_SAKLECHA 34
CS_GATE@PRITESH_SAKLECHA 35
CS_GATE@PRITESH_SAKLECHA 36
Delete nodes from BST :
(1) If node is leaf node then directly delete that node.
(2) If node having one child then assign position of node to its child and delete
that node.
(3) If node having two child then assign position of node to its inorder
predecessor or inorder successor and delete the node.

CS_GATE@PRITESH_SAKLECHA 37
CS_GATE@PRITESH_SAKLECHA 38
AVL TREE:

• AVL trees are special kind of binary search trees.


• In AVL trees, height of left subtree and right subtree of every node differs by
at most one.
• Balance factor of node = height of left subtree – height of right subtree.
• Balance factor = 0, 1, -1 is allowed.
• AVL trees are also called as self-balancing binary search trees.

CS_GATE@PRITESH_SAKLECHA 39
If tree is unbalanced then we need to perform rotation to balance the tree.
1. Left Rotation (LL Rotation)
2. Right Rotation (RR Rotation)
3. Left-Right Rotation (LR Rotation)
4. Right-Left Rotation (RL Rotation)

CS_GATE@PRITESH_SAKLECHA 40
If tree is unbalanced then we need to perform rotation to balance the tree.
1. Left Rotation (LL Rotation)
2. Right Rotation (RR Rotation)
3. Left-Right Rotation (LR Rotation)
4. Right-Left Rotation (RL Rotation)

CS_GATE@PRITESH_SAKLECHA 41
If tree is unbalanced then we need to perform rotation to balance the tree.
1. Left Rotation (LL Rotation)
2. Right Rotation (RR Rotation)
3. Left-Right Rotation (LR Rotation)
4. Right-Left Rotation (RL Rotation)

CS_GATE@PRITESH_SAKLECHA 42
If tree is unbalanced then we need to perform rotation to balance the tree.
1. Left Rotation (LL Rotation)
2. Right Rotation (RR Rotation)
3. Left-Right Rotation (LR Rotation)
4. Right-Left Rotation (RL Rotation)

CS_GATE@PRITESH_SAKLECHA 43
Construct AVL Tree for the following sequence of numbers-
(a) 1, 2, 3, 4, 5, 6, 7
(b) 7, 6, 5, 4, 3, 2, 1
(c) 50 , 20 , 60 , 10 , 8 , 15 , 32 , 46 , 11 , 48

CS_GATE@PRITESH_SAKLECHA 44
Construct AVL Tree for the following sequence of numbers-
(a) 1, 2, 3, 4, 5, 6, 7
(b) 7, 6, 5, 4, 3, 2, 1
(c) 50 , 20 , 60 , 10 , 8 , 15 , 32 , 46 , 11 , 48

CS_GATE@PRITESH_SAKLECHA 45
Construct AVL Tree for the following sequence of numbers-
(a) 1, 2, 3, 4, 5, 6, 7
(b) 7, 6, 5, 4, 3, 2, 1
(c) 50 , 20 , 60 , 10 , 8 , 15 , 32 , 46 , 11 , 48

CS_GATE@PRITESH_SAKLECHA 46
CS_GATE@PRITESH_SAKLECHA 47
CS_GATE@PRITESH_SAKLECHA 48
Maximum possible number of nodes in AVL tree of height H = 2H+1 – 1.
Minimum number of nodes in AVL Tree of height H is given by a recursive relation- N(H) =
N(H-1) + N(H-2) + 1
Minimum possible height of AVL Tree using N nodes = ⌊log2N⌋

CS_GATE@PRITESH_SAKLECHA 49
AVL Tree Deletion : Deletion is same as BST but after deletion we need to
perform balancing if resultant tree is unbalanced,
Total 6 rotations are there.

R0 R1 R-1 L0 L1 L-1
LL LL LR RR RL RR

CS_GATE@PRITESH_SAKLECHA 50
CS_GATE@PRITESH_SAKLECHA 51
CS_GATE@PRITESH_SAKLECHA 52
CS_GATE@PRITESH_SAKLECHA 53
CS_GATE@PRITESH_SAKLECHA 54
CS_GATE@PRITESH_SAKLECHA 55
Explain AVL trees. Insert the following elements in AVL search tree.

64, 1, 44, 26, 13, 110, 98, 85

CS_GATE@PRITESH_SAKLECHA 56
Insert the following data keys in the AVL Tree:
AVL 16, 23, 9, 163, 64, 29, 73, 83, 90, 96 (10 keys)

CS_GATE@PRITESH_SAKLECHA 57
Create AVL tree for the following key: 21, 26, 30, 9, 4, 14, 28, 18, 15, 10,2, 3, 7

Delete following node from the resulting tree: 2,3,10,18,4,9,14,7,15

CS_GATE@PRITESH_SAKLECHA 58
CS_GATE@PRITESH_SAKLECHA 59
CS_GATE@PRITESH_SAKLECHA 60
What is a Red-Black Tree?
A Red-Black Tree is a self-balancing binary search tree where each node has an additional attribute: a color,
which can be either red or black. The primary objective of these trees is to maintain balance during insertions
and deletions, ensuring efficient data retrieval and manipulation.

Properties of Red-Black Trees


A Red-Black Tree have the following properties:
• Each node is either red or black.
• The root of the tree is always black.
• Red nodes cannot have red children (no two consecutive red nodes on any path).
• Every path from a node to its descendant null nodes (leaves) has the same number of black nodes.
• All leaves (NIL nodes) are black.

CS_GATE@PRITESH_SAKLECHA 61
CS_GATE@PRITESH_SAKLECHA 62
Red-Black Tree Deletion Rules:
Deletion is similar to BST deletion, but additional steps are required to preserve the Red-Black properties.
The key cases are:
Step 1 Perform BST Deletion
•Find the node to be deleted.
•If the node has two children, replace it with its in-order successor (or predecessor) and proceed with
deletion.
•If the node has one child, replace the node with its child.
•If the
Step 2 node
Afterisdeleting
a leaf node, simply
a node, delete
the tree it. violate the Red-Black properties. The following rules apply to
may
restore balance:
Case 1 Deleting a Red Node
•If the deleted node was red, no violations occur since red nodes do not affect the black-height property.
•No further action is needed.
Case 2 Deleting a Black Node
•If the deleted node was black, it affects the black-height balance.
•If the node had a red child, the child replaces it and is colored black (to preserve the black height).
•If the node had no red child, we introduce a double black situation, which needs fixing.

CS_GATE@PRITESH_SAKLECHA 63
Step 3 Fixing Double Black Cases
A double black node appears when:
•A black node is deleted, and its replacement (or missing child) increases the black-height in that subtree.
To fix double black, we use rotation and recoloring:
Case 1 Sibling is Red
•If the sibling of the double black node is red, rotate the parent towards the double black node and recolor.
•This converts the case into Case 2, 3, or 4.
Case 2 Sibling is Black and Both of its Children are Black
•Recolor sibling to red to push the extra black up to the parent.
•If the parent was red, change it to black to balance the black count.
•If the parent was black, propagate the double black upwards.
Case 3 Sibling is Black, and the Near Nephew (Closer Child) is Red
•Perform a rotation on the sibling to make the far nephew red, converting the case into Case 4.
Case 4 Sibling is Black, and the Far Nephew (Distant Child) is Red
•Rotate the parent towards the double black node.
•Swap colors between the parent and the sibling.
•Recolor the far nephew to black to maintain balance.

Final Step:
If a double black propagates up to the root, it can be
removed since the root is always black.

CS_GATE@PRITESH_SAKLECHA 64
Insert the following list of elements from the red black tree. Delete the elements 18, 2, 30 from the
12, 30, 36, 18, 25, 9, 4,2, 17, 14, 20 and 47.

CS_GATE@PRITESH_SAKLECHA 65
What are Red black trees? Discuss the properties of red black trees in detail.

CS_GATE@PRITESH_SAKLECHA 66
B and B+ Trees

 B trees are specialized n-ary search trees


 B+ trees are variation of B tree.
 Each node has many keys
 Sub tree between two keys x and y contains values v such that x < v <
y
 binary search within a node to find correct sub tree.
 Binary Search tree is B tree where n = 2.

CS_GATE@PRITESH_SAKLECHA 67
B & B+ Tree Properties

CS_GATE@PRITESH_SAKLECHA 68
CS_GATE@PRITESH_SAKLECHA 69
CS_GATE@PRITESH_SAKLECHA 70
Q. Write short notes on any two of the following:
i) Queue using linked list
ii) Hashing
iii) B+ tree
iv) Post fix expression evaluation

CS_GATE@PRITESH_SAKLECHA 71
A B*-tree (B-star tree) is a variation of the B-tree data structure that provides improved space
utilization and reduces the number of disk accesses by modifying how nodes are split. It is
commonly used in database indexing and file systems.

CS_GATE@PRITESH_SAKLECHA 72
Key Differences Between B*-tree and B-tree
1.Higher Space Utilization
1. B*-trees ensure that nodes are at least 2/3 full, whereas B-trees only require nodes to be at least half full.
2. This reduces the number of splits and keeps the tree more compact, improving performance.
2.Different Node Splitting Strategy
1. In a B-tree, when a node is full and a new key is inserted, the node splits into two.
2. In a B*-tree, instead of immediately splitting, the full node tries to redistribute some of its keys to a
sibling node.
3. If redistribution is not possible, then two nodes split into three instead of just two.
3.Fewer Splits and Lower Tree Height
1. Since B*-trees split less frequently than B-trees, they often have a lower height, leading to faster searches.

Structure of a B*-tree
•Like a B-tree, each node contains multiple keys and pointers to child nodes.
•It maintains sorted order for efficient search operations.
•Internal nodes store keys to guide searches, while leaf nodes hold the actual data.

CS_GATE@PRITESH_SAKLECHA 73
B*-tree of order m is a search tree that is either empty or that satisfies three properties:

• The root node has maximum 2 *floor ((2m-2)/3) +1 children


• Other internal nodes have the minimum floor ((2m-1)/3) and maximum m children
• All external nodes are on the same level.

CS_GATE@PRITESH_SAKLECHA 74
CS_GATE@PRITESH_SAKLECHA 75
Q. Discuss Kruskal's algorithm with an following graph.

CS_GATE@PRITESH_SAKLECHA 76
CS_GATE@PRITESH_SAKLECHA 77
Q. Discuss Prims's algorithm with an following graph.

CS_GATE@PRITESH_SAKLECHA 78

You might also like