CC 215 Data Structures Trees

Slides:



Advertisements
Similar presentations
Binary Search Trees CSE 331 Section 2 James Daly.
Advertisements

Binary Trees, Binary Search Trees CMPS 2133 Spring 2008.
Binary Trees, Binary Search Trees COMP171 Fall 2006.
Trees, Binary Trees, and Binary Search Trees COMP171.
1 Trees. 2 Outline –Tree Structures –Tree Node Level and Path Length –Binary Tree Definition –Binary Tree Nodes –Binary Search Trees.
CS 206 Introduction to Computer Science II 09 / 22 / 2008 Instructor: Michael Eckmann.
Lec 15 April 9 Topics: l binary Trees l expression trees Binary Search Trees (Chapter 5 of text)
Review: Search Linear Search Binary Search Search demos: – ndan/dsal/appldsal.htmlhttp://
© 2006 Pearson Addison-Wesley. All rights reserved11 A-1 Chapter 11 Trees.
CSC 2300 Data Structures & Algorithms February 6, 2007 Chapter 4. Trees.
1 BST Trees A binary search tree is a binary tree in which every node satisfies the following: the key of every node in the left subtree is.
Binary Trees Chapter 6.
Version TCSS 342, Winter 2006 Lecture Notes Trees Binary Trees Binary Search Trees.
CS 146: Data Structures and Algorithms June 18 Class Meeting Department of Computer Science San Jose State University Summer 2015 Instructor: Ron Mak
Binary Search Trees. BST Properties Have all properties of binary tree Items in left subtree are smaller than items in any node Items in right subtree.
COSC2007 Data Structures II
Lecture Objectives  To learn how to use a tree to represent a hierarchical organization of information  To learn how to use recursion to process trees.
1 Trees Tree nomenclature Implementation strategies Traversals –Depth-first –Breadth-first Implementing binary search trees.
Tree. Basic characteristic Top node = root Left and right subtree Node 1 is a parent of node 2,5,6. –Node 2 is a parent of node.
Lecture 10 Trees –Definiton of trees –Uses of trees –Operations on a tree.
CMSC 341 Introduction to Trees. 8/3/2007 UMBC CMSC 341 TreeIntro 2 Tree ADT Tree definition  A tree is a set of nodes which may be empty  If not empty,
DATA STRUCTURES AND ALGORITHMS Lecture Notes 5 Prepared by İnanç TAHRALI.
Chapter 6 Binary Trees. 6.1 Trees, Binary Trees, and Binary Search Trees Linked lists usually are more flexible than arrays, but it is difficult to use.
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.
Trees, Binary Trees, and Binary Search Trees COMP171.
Trees  Linear access time of linked lists is prohibitive Does there exist any simple data structure for which the running time of most operations (search,
Lec 15 Oct 18 Binary Search Trees (Chapter 5 of text)
Data Structures TREES.
Trees : Part 1 Section 4.1 (1) Theory and Terminology (2) Preorder, Postorder and Levelorder Traversals.
CSE 326: Data Structures Lecture #6 From Lists to Trees Henry Kautz Winter 2002.
1 Storing Hierarchical Information Lists, Stacks, and Queues represent linear sequences Data often contain hierarchical relationships that cannot be expressed.
Min Chen School of Computer Science and Engineering Seoul National University Data Structure: Chapter 6.
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.
CISC 235 Topic 3 General Trees, Binary Trees, Binary Search Trees.
Binary Tree. Some Terminologies Short review on binary tree Tree traversals Binary Search Tree (BST)‏ Questions.
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.
Rooted Tree a b d ef i j g h c k root parent node (self) child descendent leaf (no children) e, i, k, g, h are leaves internal node (not a leaf) sibling.
24 January Trees CSE 2011 Winter Trees Linear access time of linked lists is prohibitive  Does there exist any simple data structure for.
1 Trees General Trees  Nonrecursive definition: a tree consists of a set of nodes and a set of directed edges that connect pairs of nodes.
Definitions Read Weiss, 4.1 – 4.2 Implementation Nodes and Links One Arrays Three Arrays Traversals Preorder, Inorder, Postorder K-ary Trees Converting.
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 CSE 326: Data Structures Trees Lecture 6: Friday, Jan 17, 2003.
Trees CSIT 402 Data Structures II 1. 2 Why Do We Need Trees? Lists, Stacks, and Queues are linear relationships Information often contains hierarchical.
1 CMSC 341 Introduction to Trees Textbook sections:
DS.T.1 Trees Chapter 4 Overview Tree Concepts Traversals Binary Trees Binary Search Trees AVL Trees Splay Trees B-Trees.
CSE 373 Data Structures Lecture 7
Trees Chapter 15.
CMSC 341 Introduction to Trees 8/3/2007 CMSC 341 Tree Intro.
UNIT III TREES.
CMSC 341 Introduction to Trees.
CSE 373 Data Structures Lecture 7
i206: Lecture 13: Recursion, continued Trees
Binary Trees, Binary Search Trees
TREES General trees Binary trees Binary search trees AVL trees
General Trees & Binary Trees
Trees CSE 373 Data Structures.
Trees.
CMSC 202 Trees.
Data Structures and Algorithm Analysis Trees
Binary Trees, Binary Search Trees
CE 221 Data Structures and Algorithms
CMSC 341 Introduction to Trees CMSC 341 Tree Intro.
Tree.
Trees.
Trees CSE 373 Data Structures.
Trees CSE 373 Data Structures.
Binary Trees, Binary Search Trees
Presentation transcript:

CC 215 Data Structures Trees AASTMT Engineering and Technology College CC 215 Data Structures Trees Lecture 8 Dr. Manal Helal - Fall 2014

Readings Reading Chapter 4.1-4.3

Why Do We Need Trees? Lists, Stacks, and Queues are linear relationships Information often contains hierarchical relationships File directories or folders Moves in a game Hierarchies in organizations Can build a tree to support fast searching

Tree Jargon root nodes and edges leaves parent, children, siblings ancestors, descendants subtrees path, path length height, depth A B C D E F

More Tree Jargon Length of a path = number of edges Depth of a node N = length of path from root to N Height of node N = length of longest path from N to a leaf Depth of tree = depth of deepest node Height of tree = height of root depth=0, height = 2 A B C D depth=1, height =0 E F depth = 2, height=0

Definition and Tree Trivia A tree is a set of nodes,i.e., either it’s an empty set of nodes, or it has one node called the root from which zero or more trees (subtrees) descend Two nodes in a tree have at most one path between them Can a non-zero path from node N reach node N again? No. Trees can never have cycles (loops)

Paths A tree with N nodes always has N-1 edges (prove it by induction) Base Case: N=1 one node, zero edges Inductive Hypothesis: Suppose that a tree with N=k nodes always has k-1 edges. Induction: Suppose N=k+1… The k+1st node must connect to the rest by 1 or more edges. If more, we get a cycle. So it connects by just 1 more edge k +1

Implementation of Trees One possible pointer-based Implementation tree nodes with value and a pointer to each child but how many pointers should we allocate space for? A more flexible pointer-based implementation 1st Child / Next Sibling List Representation Each node has 2 pointers: one to its first child and one to next sibling Can handle arbitrary number of children

Arbitrary Branching A B C D E F A B C D E F Data FirstChild Sibling Nodes of same depth B C D B C D E F E F Data FirstChild Sibling

Binary Trees Every node has at most two children Most popular tree in computer science Given N nodes, what is the minimum depth of a binary tree? (This means all levels but the last are full!) At depth d, you can have N = 2d to N = 2d+1-1 nodes

Minimum depth vs node count At depth d, you can have N = 2d to 2d+1-1 nodes minimum depth d is (log N) T(n) = (f(n)) means T(n) = O(f(n)) and f(n) = O(T(n)), i.e. T(n) and f(n) have the same growth rate 1 2 3 d=2 N=22 to 23-1 (i.e, 4 to 7 nodes) 4 5 6 7

Maximum depth vs node count What is the maximum depth of a binary tree? Degenerate case: Tree is a linked list! Maximum depth = N-1 Goal: Would like to keep depth at around log N to get better performance than linked list for operations like Find

A degenerate tree A linked list with high overhead 1 A linked list with high overhead and few redeeming characteristics 2 3 4 5 6 7 Trees - Lecture 7 12/26/03

Traversing Binary Trees The definitions of the traversals are recursive definitions. For example: Visit the root Visit the left subtree (i.e., visit the tree whose root is the left child) and do this recursively Visit the right subtree (i.e., visit the tree whose root is the right child) and do this recursively Traversal definitions can be extended to general (non-binary) trees

Traversing Binary Trees Preorder: Node, then Children (starting with the left) recursively + * + A B C D Inorder: Left child recursively, Node, Right child recursively A + B * C + D Postorder: Children recursively, then Node A B + C * D + + D * C + A B

Binary Search Trees Binary search trees are binary trees in which all values in the node’s left subtree are less than node value all values in the node’s right subtree are greater than node value Operations: Find, FindMin, FindMax, Insert, Delete What happens when we traverse the tree in inorder? 9 5 94 10 97 96 99

Operations on Binary Search Trees How would you implement these? Recursive definition of binary search trees allows recursive routines Call by reference helps too FindMin FindMax Find Insert Delete 9 5 94 10 97 96 99

Binary SearchTree 9 9 5 94 5 94 10 97 10 97 96 99 data 96 99 left right

Find Find(T : tree pointer, x : element): tree pointer { case { T = null : return null; T.data = x : return T; T.data > x : return Find(T.left,x); T.data < x : return Find(T.right,x) }

FindMin Design recursive FindMin operation that returns the smallest element in a binary search tree. FindMin(T : tree pointer) : tree pointer { // precondition: T is not null // ??? }

Insert Operation ? Example: Insert 95 Do a “Find” operation for X Insert(T: tree, X: element) Do a “Find” operation for X If X is found  update (no need to insert) Else, “Find” stops at a NULL pointer Insert Node with X there Example: Insert 95 94 ? 10 97 96 99

Insert 95 94 94 10 97 10 97 96 99 96 99 95

Insert Done with call-by-reference Insert(T : reference tree pointer, x : element) : integer { if T = null then T := new tree; T.data := x; return 1;//the links to //children are null case T.data = x : return 0; T.data > x : return Insert(T.left, x); T.data < x : return Insert(T.right, x); endcase } This is where call by reference makes a difference. Advantage of reference parameter is that the call has the original pointer not a copy.

Call by Value vs Call by Reference Copy of parameter is used Call by reference Actual parameter is used F(p) p p used inside call of F

Delete Operation Delete is a bit trickier…Why? Suppose you want to delete 10 Strategy: Find 10 Delete the node containing 10 Problem: When you delete a node, what do you replace it by? 94 10 97 5 24 11 17

Delete Operation Problem: When you delete a node, what do you replace it by? Solution: If it has no children, by NULL If it has 1 child, by that child If it has 2 children, by the node with the smallest value in its right subtree (the successor of the node) 94 10 97 5 24 11 17

Delete “5” - No children Find 5 node Then Free the 5 node and NULL the 94 94 Find 5 node 10 97 10 97 5 24 5 24 Then Free the 5 node and NULL the pointer to it 11 11 17 17

Delete “24” - One child 94 94 Find 24 node 10 97 10 97 5 24 5 24 Then Free the 24 node and replace the pointer to it with a pointer to its child 11 11 17 17

Delete “10” - two children Find 10, Copy the smallest value in right subtree into the node 94 94 10 97 11 97 5 24 5 24 Then (recursively) Delete node with smallest value in right subtree Note: it cannot have two children (why?) 11 11 17 17

Then Delete “11” - One child 94 94 Remember 11 node 11 97 11 97 5 24 5 24 Then Free the 11 node and replace the pointer to it with a pointer to its child 11 11 17 17

Remove from Text private BinaryNode remove( Comparable x, BinaryNode t) { if ( t == null) return t; // not found if ( x.compareTo( t.element ) < 0 ) t.left = remove( x, t.left ); // search left else if ( x.compareTo( t.element) > 0 ) t.right = remove(x, t.right ); // search right else if (t.left != null && t.right != null) // found it; two children { t.element = findMin (t.right ).element; // find the min, replace, t.right = remove( t.element, t.right); } and remove it else t = (t.left != null ) ? t.left : t.right; // found it; one child return t; }

FindMin Solution FindMin(T : tree pointer) : tree pointer { // precondition: T is not null // if T.left = null return T else return FindMin(T.left) } Note: Look at the “remove” method in the book.