TREES. What is a tree ? An Abstract Data Type which emulates a tree structure with a set of linked nodes The nodes within a tree are organized in a hierarchical.

Slides:



Advertisements
Similar presentations
Chapter 10: Trees. Definition A tree is a connected undirected acyclic (with no cycle) simple graph A collection of trees is called forest.
Advertisements

Introduction to Trees Chapter 6 Objectives
TREES Chapter 6. Trees - Introduction  All previous data organizations we've studied are linear—each element can have only one predecessor and successor.
Main Index Contents 11 Main Index Contents Week 6 – Binary Trees.
Binary Trees, Binary Search Trees CMPS 2133 Spring 2008.
Binary Trees, Binary Search Trees COMP171 Fall 2006.
CS 171: Introduction to Computer Science II
Trees Chapter Chapter Contents Tree Concepts Hierarchical Organizations Tree Terminology Traversals of a Tree Traversals of a Binary Tree Traversals.
© 2006 Pearson Addison-Wesley. All rights reserved11 A-1 Chapter 11 Trees.
Trees Chapter 25 Slides by Steve Armstrong LeTourneau University Longview, TX  2007,  Prentice Hall.
1 Chapter 7 Trees. 2 What is a Tree In computer science, a tree is an abstract model of a hierarchical structure A tree consists of nodes with a parent-child.
KNURE, Software department, Ph , N.V. Bilous Faculty of computer sciences Software department, KNURE The trees.
Joseph Lindo Trees Sir Joseph Lindo University of the Cordilleras.
Trees Chapter 8. 2 Tree Terminology A tree consists of a collection of elements or nodes, organized hierarchically. The node at the top of a tree is called.
Advanced Algorithms Analysis and Design Lecture 8 (Continue Lecture 7…..) Elementry Data Structures By Engr Huma Ayub Vine.
Trees & Graphs Chapter 25 Carrano, Data Structures and Abstractions with Java, Second Edition, (c) 2007 Pearson Education, Inc. All rights reserved X.
Chapter 19: Binary Trees. Objectives In this chapter, you will: – Learn about binary trees – Explore various binary tree traversal algorithms – Organize.
Introduction Of Tree. Introduction A tree is a non-linear data structure in which items are arranged in sequence. It is used to represent hierarchical.
CS Data Structures Chapter 5 Trees. Chapter 5 Trees: Outline  Introduction  Representation Of Trees  Binary Trees  Binary Tree Traversals 
Lecture 10 Trees –Definiton of trees –Uses of trees –Operations on a tree.
Trees CSC 172 SPRING 2002 LECTURE 14. Lists We have seen lists: public class Node { Object data; Node next; } 
Binary Trees 2 Overview Trees. Terminology. Traversal of Binary Trees. Expression Trees. Binary Search Trees.
Tree (new ADT) Terminology:  A tree is a collection of elements (nodes)  Each node may have 0 or more successors (called children)  How many does a.
Binary Trees, Binary Search Trees RIZWAN REHMAN CENTRE FOR COMPUTER STUDIES DIBRUGARH UNIVERSITY.
Tree Data Structures.
Data Structures and Algorithm Analysis Trees Lecturer: Jing Liu Homepage:
Compiled by: Dr. Mohammad Omar Alhawarat
Trees Chapter 8. 2 Tree Terminology A tree consists of a collection of elements or nodes, organized hierarchically. The node at the top of a tree is called.
Prof. Amr Goneid, AUC1 CSCE 210 Data Structures and Algorithms Prof. Amr Goneid AUC Part 4. Trees.
Data Structures TREES.
Data Structures & Algorithm Analysis Muhammad Hussain Mughal Trees. Binary Trees. Reading: Chap.4 ( ) Weiss.
Trees : Part 1 Section 4.1 (1) Theory and Terminology (2) Preorder, Postorder and Levelorder Traversals.
1 Storing Hierarchical Information Lists, Stacks, and Queues represent linear sequences Data often contain hierarchical relationships that cannot be expressed.
Tree Traversals, TreeSort 20 February Expression Tree Leaves are operands Interior nodes are operators A binary tree to represent (A - B) + C.
Introduction to Trees IT12112 Lecture 05 Introduction Tree is one of the most important non-linear data structures in computing. It allows us to implement.
Trees By P.Naga Srinivasu M.tech,(MBA). Basic Tree Concepts A tree consists of finite set of elements, called nodes, and a finite set of directed lines.
M180: Data Structures & Algorithms in Java Trees & Binary Trees Arab Open University 1.
CMSC 341 Introduction to Trees. 2/21/20062 Tree ADT Tree definition –A tree is a set of nodes which may be empty –If not empty, then there is a distinguished.
1 Chapter 4 Trees Basic concept How tree are used to implement the file system How tree can be used to evaluate arithmetic expressions How to use trees.
Chapter 10: Trees A tree is a connected simple undirected graph with no simple circuits. Properties: There is a unique simple path between any 2 of its.
24 January Trees CSE 2011 Winter Trees Linear access time of linked lists is prohibitive  Does there exist any simple data structure for.
Data Structures Azhar Maqsood School of Electrical Engineering and Computer Sciences (SEECS-NUST) Binary Trees.
Foundation of Computing Systems Lecture 4 Trees: Part I.
Trees (Unit 7).
Graphs and Trees Mathematical Structures for Computer Science Chapter 5 Copyright © 2006 W.H. Freeman & Co.MSCS SlidesGraphs and Trees.
BINARY TREES Objectives Define trees as data structures Define the terms associated with trees Discuss tree traversal algorithms Discuss a binary.
TREES General trees Binary trees Binary search trees AVL trees Balanced and Threaded trees.
1 Trees : Part 1 Reading: Section 4.1 Theory and Terminology Preorder, Postorder and Levelorder Traversals.
TREE Ahsan Ahmed College of Computer and Information Science Majma’ah University 1.
1 Trees. 2 Trees Trees. Binary Trees Tree Traversal.
What is a Tree? Formally, we define a tree T as a set of nodes storing elements such that the nodes have a parent-child relationship, that satisfies the.
Prof. Amr Goneid, AUC1 CSCE 210 Data Structures and Algorithms Prof. Amr Goneid AUC Part 4. Trees.
Trees Chapter 15.
Data Structure and Algorithms
CSCE 210 Data Structures and Algorithms
Lecture 1 (UNIT -4) TREE SUNIL KUMAR CIT-UPES.
Binary Trees "A tree may grow a thousand feet tall, but its leaves will return to its roots." -Chinese Proverb.
i206: Lecture 13: Recursion, continued Trees
Binary Trees, Binary Search Trees
TREES General trees Binary trees Binary search trees AVL trees
Trees and Binary Trees.
Week nine-ten: Trees Trees.
Binary Trees, Binary Search Trees
Trees.
Binary Trees.
Binary Trees, Binary Search Trees
Data Structures Using C++ 2E
Introduction to Trees Chapter 6 Objectives
Trees.
NATURE VIEW OF A TREE leaves branches root. NATURE VIEW OF A TREE leaves branches root.
Presentation transcript:

TREES

What is a tree ? An Abstract Data Type which emulates a tree structure with a set of linked nodes The nodes within a tree are organized in a hierarchical manner Nodes higher in levels are called parent, while the ones in lower levels are called child nodes Each node can have at most one parent and multiple number of children A link between two nodes is called an edge Levels Parent Children Node Edges

Possible Uses Organization Charts File Systems Artificial Intelligence – Decision Trees – Evolutionary Algorithms (Genetic Programming) Class Hierarchy in Object Oriented Programming environment

Organizational Charts

Using trees in file system

Inheritance in OOP

Decision Trees in Tic-Tac-Toe

Decision Tree in an expert system

Genetic Programming Tree

Tree Terminology Root Node – The node without any parent – A tree can have only one root node A node referencing nodes lower in the hierarchy is called a parent node (labeled p in the figure) The node(s) referred by a parent node is(are) called child nodes (labeled c in figure) p c Root

Tree Terminology (Siblings) Child nodes of the same parent are called siblings (shown red in the figure)

Tree Terminology (Internal Nodes) A node have one or more children is termed as internal node (labeled in red in the figure)

Tree Terminology (Leaf/External Node) A node is an external or leaf node if it has no child nodes (labeled red in the figure)

Tree Terminology (Ancestor/Descendent) An ancestor of a node is either the node’s parent, grand parent, grand grand parent and so) A Descendent of a node is child, grand child, grand grand child and so on u v u v

Tree Terminology (Subtree) A tree may be divided into subtrees. A subtree is a tree that has the child of a node as its root. Hence, a subtree is composed of a node and all of that node’s descendants. The first node in a subtree is known as the root of the subtree and is used to name the subtree. Subtrees themselves can be further divided into other subtrees.

Tree Terminology (Subtree) The subtree of T rooted at node v is the tree consisting of all the descendents of v in T (including v) tree consisting of a node and its descendants v v Root of subtree

Tree Terminology (Depth of a node) – The depth of a node v in T is the number of ancestors of v, excluding v itself. – More formally: If v is the root, the depth of v is 0 depth of v = 1 depth of v = 3 v v

Tree Terminology( Height /depth of a tree) The depth of a tree is the maximum depth of any of its leaves maximum levels of a tree tree depth = 3 tree depth = 2 tree depth = 0

Terminology Two nodes are adjacent if a branch connects them. A path is a sequence of nodes in which each node is adjacent to the next one. Every node in the tree can be reached by following a unique path starting from the root. The length of this path is the number of edges on the path. There is a path of length 0 from every node to itself.

Terminology The path from the root, A, to the leaf, I, is denoted as AFI and has a length of 2. ABD is the path from the root, A, to the leaf, D, and also has a length of 2.

Types of Trees General tree – a node can have any number of children Binary tree – a node can have at most two children

Binary Tree

Binary Trees The simplest form of tree is a Binary Tree A Binary Tree consists of – (a) A node (called the root node) and – (b) Left and right subtrees – Both the subtrees are themselves binary trees Note: this is a recursive definition (A node can’t have more than 2 children) General tree Binary tree

Binary Trees Finite set of nodes that is either empty, or consists of a root and two disjoint binary trees called the left subtree and right subtree. – Node contains information and two pointers to other nodes – Each node has at most two children

A binary tree is either empty or has the following form: Where Tleft and Tright are binary trees. root TLTL TRTR

Binary Trees Full binary tree: All leaves on the same level and every node has either zero or two children. Complete binary tree: Leaves are filled from left to right on one level before moving to next level.

Binary Trees

Skewed binary tree: Contains only left or right children. Similar: Two trees with same structure and different data. Copy or identical: Same structure and same data.

Tree Height and Full Binary Tree If h = height of a binary tree, max # of leaves = 2 h max # of nodes = 2 h A binary tree with height h and 2 h nodes (or 2 h leaves) is called a full binary tree Binary tree

Visiting and Traversing a Node Many applications require that all of the nodes of a tree be “visited”. Visiting a node may mean printing contents, retrieving information, making a calculation, etc. Traverse: To visit all the nodes in a tree in a systematic fashion. – A traversal can pass through a node without visiting it at that moment.

Binary Tree Structure The representation of a binary tree structure is relatively straightforward. We need a variable to store the data at the node and 2 pointers to the left and right subtrees. struct Node { int data Node *left Node *right }

Binary Tree Structure

Traversing Binary Trees Traversing means visiting each node in a specified order Traversing is a slow process as compared to insertion, deletion There are many applications where traversing a tree is required

Possible ways of traversal Pre-order (Depth-First) – Visit the parent node, then the left subtree and lastly the right subtree In-order – Traverse the left subtree first then the parent node and then at last the right subtree Post-order – Visit the left subtree then the right subtree and finally the parent node Level-order (Breadth-First) – Subtrees are visited successively starting the root node and then nodes are visited from left to right on each level.

Graphical Representation

Preorder Traversal

Inorder Traversal

In an inorder traversal a node is visited after its left subtree and before its right Subtree Application: draw a binary tree or Arithmetic expression printing ((2 × (a − 1)) + (3 × b))

Example of Binary Tree (inorder)

Post Order Traversal

Expression Trees + a bc × ×+ × de f g + Expression tree for ( a + b × c) + ((d ×e + f) × g) There are three notations for a mathematical expression: 1) Infix notation : ( a + (b × c)) + (((d ×e) + f) × c) 2) Postfix notation: a b c × + d e × f + g * + 3) Prefix notation : + + a × b c × + × d e f g

Expression Tree traversals Depending on how we traverse the expression tree, we can produce one of these notations for the expression represented by the three. Inorder traversal produces infix notation. » This is a overly parenthesized notation. » Print out the operator, then print put the left subtree inside parentheses, and then print out the right subtree inside parentheses. Postorder traversal produces postfix notation. » Print out the left subtree, then print out the right subtree, and then printout the operator. Preorder traversal produces prefix notation. » Print out the operator, then print out the right subtree, and then print out the left subtree.

Summary Preorder (Depth-First) traversal sequence: F, B, A, D, C, E, G, I, Inorder traversal sequence: A, B, C, D, E, F, G, H,I Postorder traversal sequence: A, C, E, D, B, H, I, G, F Breadth-First traversal sequence: F, B, G, A, D, I, C, E, H