KEMBAR78
Trees in data structures | PPTX
Trees in Data Structure
Mrs.R.Sabitha M.Sc.,M.Phil.,
Assistant Professor,
Department of Computer Science
Preliminaries
 Tree is a non- linear data structure.
 A Tree is a recursive data structure containing the set
of one or more data nodes where one node is
designated as the root of the tree while the remaining
nodes are called as the children of the root.
 The nodes other than the root node are partitioned
into the non empty sets where each one of them is to
be called sub-tree.
 Nodes of a tree either maintain a parent-child
relationship between them or they are sister
nodes.
 In a general tree, A node can have any number of
children nodes but it can have only a single parent.
 The following image shows a tree, where the node
A is the root node of the tree while the other nodes
can be seen as the children of A.
Tree Structure
Basic terminology
 Root Node :- The root node is the topmost node in the tree hierarchy. In
other words, the root node is the one which doesn't have any parent.
 Sub Tree :- If the root node is not null, the tree T1, T2 and T3 is called sub-
trees of the root node.
 Leaf Node :- The node of tree, which doesn't have any child node, is called
leaf node. Leaf node is the bottom most node of the tree. There can be any
number of leaf nodes present in a general tree. Leaf nodes can also be
called external nodes.
 Path :- The sequence of consecutive edges is called path. In the tree shown
in the above image, path to the node E is A→ B → E.
Tree Example
Basic terminology
Tree Example
 Ancestor node :- An ancestor of a node is any predecessor node on a path
from root to that node. The root node doesn't have any ancestors. In the
tree shown in the above image, the node F have the ancestors, B and A.
 Degree :- Degree of a node is equal to number of children, a node have. In
the tree shown in the above image, the degree of node B is 2. Degree of a
leaf node is always 0 while in a complete binary tree, degree of each node is
equal to 2.
 Level Number :- Each node of the tree is assigned a level number in such a
way that each node is present at one level higher than its parent. Root node
of the tree is always present at level 0.
NextNext1
Structure of Tree Representation
struct node
{
int root;
struct node *parent;
struct node *lchild
struct node *rchild;
}
Types of Tree
The tree data structure can be classified
into six different categories.
1.Binary tree
2.Binary search tree
3.Expression tree
Binary Tree
Binary tree is a data structure in which each
node can have at most 2 children.
The node present at the top most level is
called the root node.
A node with the 0 children is called leaf node.
Binary Trees are used in the applications like
expression evaluation and many more.
Example of Binary Tree
Binary search tree
 Binary search tree is an ordered binary tree.
 All the elements in the left sub-tree are less than the root
while elements present in the right sub-tree are greater than
or equal to the root node element.
 Binary search trees are used in most of the applications of
computer science domain like searching, sorting, etc.
Binary search tree example
Expression tree
 Expression trees are used to evaluate the simple
arithmetic expressions.
 Expression tree is basically a binary tree where
internal nodes are represented by operators while
the leaf nodes are represented by operands.
 Expression trees are widely used to solve algebraic
expressions like (a+b)*(a-b). Consider the following
example.
Construct an expression tree by using the following
algebraic expression.
(a + b) / (a*b - c) + d
Thank You.

Trees in data structures

  • 1.
    Trees in DataStructure Mrs.R.Sabitha M.Sc.,M.Phil., Assistant Professor, Department of Computer Science
  • 2.
    Preliminaries  Tree isa non- linear data structure.  A Tree is a recursive data structure containing the set of one or more data nodes where one node is designated as the root of the tree while the remaining nodes are called as the children of the root.  The nodes other than the root node are partitioned into the non empty sets where each one of them is to be called sub-tree.
  • 3.
     Nodes ofa tree either maintain a parent-child relationship between them or they are sister nodes.  In a general tree, A node can have any number of children nodes but it can have only a single parent.  The following image shows a tree, where the node A is the root node of the tree while the other nodes can be seen as the children of A.
  • 4.
  • 5.
    Basic terminology  RootNode :- The root node is the topmost node in the tree hierarchy. In other words, the root node is the one which doesn't have any parent.  Sub Tree :- If the root node is not null, the tree T1, T2 and T3 is called sub- trees of the root node.  Leaf Node :- The node of tree, which doesn't have any child node, is called leaf node. Leaf node is the bottom most node of the tree. There can be any number of leaf nodes present in a general tree. Leaf nodes can also be called external nodes.  Path :- The sequence of consecutive edges is called path. In the tree shown in the above image, path to the node E is A→ B → E. Tree Example
  • 6.
    Basic terminology Tree Example Ancestor node :- An ancestor of a node is any predecessor node on a path from root to that node. The root node doesn't have any ancestors. In the tree shown in the above image, the node F have the ancestors, B and A.  Degree :- Degree of a node is equal to number of children, a node have. In the tree shown in the above image, the degree of node B is 2. Degree of a leaf node is always 0 while in a complete binary tree, degree of each node is equal to 2.  Level Number :- Each node of the tree is assigned a level number in such a way that each node is present at one level higher than its parent. Root node of the tree is always present at level 0.
  • 7.
  • 8.
    Structure of TreeRepresentation struct node { int root; struct node *parent; struct node *lchild struct node *rchild; }
  • 9.
    Types of Tree Thetree data structure can be classified into six different categories. 1.Binary tree 2.Binary search tree 3.Expression tree
  • 10.
    Binary Tree Binary treeis a data structure in which each node can have at most 2 children. The node present at the top most level is called the root node. A node with the 0 children is called leaf node. Binary Trees are used in the applications like expression evaluation and many more.
  • 11.
  • 12.
    Binary search tree Binary search tree is an ordered binary tree.  All the elements in the left sub-tree are less than the root while elements present in the right sub-tree are greater than or equal to the root node element.  Binary search trees are used in most of the applications of computer science domain like searching, sorting, etc.
  • 13.
  • 14.
    Expression tree  Expressiontrees are used to evaluate the simple arithmetic expressions.  Expression tree is basically a binary tree where internal nodes are represented by operators while the leaf nodes are represented by operands.  Expression trees are widely used to solve algebraic expressions like (a+b)*(a-b). Consider the following example.
  • 15.
    Construct an expressiontree by using the following algebraic expression. (a + b) / (a*b - c) + d
  • 16.