Trees Chapter 19, 20 Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013.

Slides:



Advertisements
Similar presentations
Chapter 7. Binary Search Trees
Advertisements

Binary Trees CSC 220. Your Observations (so far data structures) Array –Unordered Add, delete, search –Ordered Linked List –??
1 abstract containers hierarchical (1 to many) graph (many to many) first ith last sequence/linear (1 to 1) set.
TREES Chapter 6. Trees - Introduction  All previous data organizations we've studied are linear—each element can have only one predecessor and successor.
Binary Trees, Binary Search Trees CMPS 2133 Spring 2008.
Binary Trees, Binary Search Trees COMP171 Fall 2006.
1 Trees Tree nomenclature Implementation strategies Traversals –Depth-first –Breadth-first Implementing binary trees Reading: L&C 9.1 – 9.7.
© 2006 Pearson Addison-Wesley. All rights reserved11 B-1 Chapter 11 (continued) Trees.
Trees Chapter Chapter Contents Tree Concepts Hierarchical Organizations Tree Terminology Traversals of a Tree Traversals of a Binary Tree Traversals.
Data Structures: Trees i206 Fall 2010 John Chuang Some slides adapted from Marti Hearst, Brian Hayes, or Glenn Brookshear.
Fall 2007CS 2251 Trees Chapter 8. Fall 2007CS 2252 Chapter Objectives To learn how to use a tree to represent a hierarchical organization of information.
Data Structures Data Structures Topic #8. Today’s Agenda Continue Discussing Table Abstractions But, this time, let’s talk about them in terms of new.
Trees Chapter 25 Slides by Steve Armstrong LeTourneau University Longview, TX  2007,  Prentice Hall.
Chapter 13 Binary Search Trees. Copyright © 2005 Pearson Addison-Wesley. All rights reserved Chapter Objectives Define a binary search tree abstract.
1 abstract containers hierarchical (1 to many) graph (many to many) first ith last sequence/linear (1 to 1) set.
Chapter 12 Trees. Copyright © 2005 Pearson Addison-Wesley. All rights reserved Chapter Objectives Define trees as data structures Define the terms.
Trees Chapter 23 Copyright ©2012 by Pearson Education, Inc. All rights reserved.
Fundamentals of Python: From First Programs Through Data Structures
CHAPTER 12 Trees. 2 Tree Definition A tree is a non-linear structure, consisting of nodes and links Links: The links are represented by ordered pairs.
Marc Smith and Jim Ten Eyck
Binary and Other Trees CSE, POSTECH. 2 2 Linear Lists and Trees Linear lists are useful for serially ordered data – (e 1,e 2,e 3,…,e n ) – Days of week.
Binary Trees Chapter 6.
Version TCSS 342, Winter 2006 Lecture Notes Trees Binary Trees Binary Search Trees.
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.
Compiled by: Dr. Mohammad Alhawarat BST, Priority Queue, Heaps - Heapsort CHAPTER 07.
Trees & Graphs Chapter 25 Carrano, Data Structures and Abstractions with Java, Second Edition, (c) 2007 Pearson Education, Inc. All rights reserved X.
1 Trees Tree nomenclature Implementation strategies Traversals –Depth-first –Breadth-first Implementing binary search trees.
Chapter 10 Trees – part B.
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.
Searching: Binary Trees and Hash Tables CHAPTER 12 6/4/15 Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education,
Lecture 10 Trees –Definiton of trees –Uses of trees –Operations on a tree.
© 2010 Pearson Addison-Wesley. All rights reserved. Addison Wesley is an imprint of CHAPTER 10: Binary Search Trees Java Software Structures: Designing.
© 2011 Pearson Addison-Wesley. All rights reserved 11 B-1 Chapter 11 (continued) Trees.
Topic 14 The BinaryTree ADT Objectives Define trees as data structures Define the terms associated with trees Discuss tree traversal algorithms.
Trees CSCI Objectives Define trees as data structures Define the terms associated with trees Discuss the possible implementations of trees Analyze.
Spring 2010CS 2251 Trees Chapter 6. Spring 2010CS 2252 Chapter Objectives Learn to use a tree to represent a hierarchical organization of information.
Chapter 19 Implementing Trees and Priority Queues Fundamentals of Java.
Chapter 10-A Trees Modified
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.
Starting at Binary Trees
Topic 15 The Binary Search Tree ADT Binary Search Tree A binary search tree (BST) is a binary tree with an ordering property of its elements, such.
© 2010 Pearson Addison-Wesley. All rights reserved. Addison Wesley is an imprint of CHAPTER 12: Multi-way Search Trees Java Software Structures: Designing.
Chapter 20 Binary Search Trees
Linked Structures - Review Chapter 13 Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013.
M180: Data Structures & Algorithms in Java Trees & Binary Trees Arab Open University 1.
Week 10 - Friday.  What did we talk about last time?  Graph representations  Adjacency matrix  Adjacency lists  Depth first search.
Trees Chapter Chapter Contents Tree Concepts Hierarchical Organizations Tree Terminology Traversals of a Tree Traversals of a Binary Tree Traversals.
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.
TREES K. Birman’s and G. Bebis’s Slides. Tree Overview 2  Tree: recursive data structure (similar to list)  Each cell may have zero or more successors.
Week 15 – Wednesday.  What did we talk about last time?  Review up to Exam 1.
Recursion Chapter 17 Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013.
BINARY TREES Objectives Define trees as data structures Define the terms associated with trees Discuss tree traversal algorithms Discuss a binary.
Linked Structures Chapter 13 Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013.
1 Binary Search Trees What are the disadvantages of using a linked list? What are the disadvantages of using an array- based list? Binary search trees.
TREES From root to leaf. Trees  A tree is a non-linear collection  The elements are in a hierarchical arrangement  The elements are not accessible.
The Tree ADT.
Trees Chapter 15.
Trees Tree nomenclature Implementation strategies Traversals
Recall: Nodes and Linked Lists
Binary Trees, Binary Search Trees
Binary Tree and General Tree
Chapter 20: Binary Trees.
Chapter 22 : Binary Trees, AVL Trees, and Priority Queues
Chapter 21: Binary Trees.
Find in a linked list? first last 7  4  3  8 NULL
Trees.
Chapter 20 Binary Search Trees
Tree (new ADT) Terminology: A tree is a collection of elements (nodes)
Presentation transcript:

Trees Chapter 19, 20 Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 2 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 2 Scope Trees :  Trees as data structures  Tree terminology  Tree implementations  Analyzing tree efficiency  Tree traversals  Expression trees

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 3 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 3 Trees A tree is a non-linear structure in which elements are organized into a hierarchy A tree is comprised of a set of nodes in which elements are stored and edges connect one node to another Each node is located on a particular level There is only one root node in the tree Nodes EdgesRoot Node Root Level 0 Level 1 Level 2

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 4 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 4 Trees Nodes at the lower level of a tree are the children of nodes at the previous level A node can have only one parent, but may have multiple children Nodes that have the same parent are siblings The root is the only node which has no parent SiblingsRoot Node ANode BNode C Node DNode E Node A is the Parent of Nodes D and E Level 0 Level 1 Level 2 Children of Node A

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 5 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 5 Trees A node that has no children is a leaf node A node that is not the root and has at least one child is an internal node A subtree is a tree structure that makes up part of another tree We can follow a path through a tree from parent to child, starting at the root A node is an ancestor of a node if it is above it on the path from the root.

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 6 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 6 Trees Nodes that can be reached by following a path from a particular node are the descendants of that node The level of a node is the length of the path from the root to the node The path length is the number of edges to get from the root to the node The height of a tree is the length of the longest path from the root to a leaf Root Node ANode BNode C Node DNode E Level 0 Level 1 Level 2 Height = 2

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 7 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 7 Trees – Quiz What are the descendents of node B? What is the level of node E? What is the path length to get from the root to node G? What is the height of this tree?

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 8 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 8 Classifying Trees Trees can be classified in many ways One important criterion is the maximum number of children any node in the tree may have This may be referred to as the order of the tree General trees have no limit to the number of children a node may have A tree that limits each node to no more than n children is referred to as an n-ary tree The tree for play TicTacToe is an 9-ary tree (at most 9 moves)

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 9 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 9 Binary Trees Trees in which nodes may have at most two children are called binary trees Root Node ANode B Node CNode D Node ENode F

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 10 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 10 Balanced Trees A tree is balanced if all of the leaves of the tree are on the same level or within one level of each other

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 11 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 11 Full and Complete Trees A balanced n-ary tree with m elements has a height of log n m A balanced binary tree with n nodes has a height of log 2 n An n-ary tree is full if all leaves of the tree are at the same height and every non-leaf node has exactly n children A tree is complete if it is full, or full to the next-to-last level with all leaves at the bottom level on the left side of the tree Root Node ANode B Node CNode D Node ENode F Full Binary Tree Root Node ANode B Node CNode D Node E Complete Binary Tree

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 12 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 12 Full and Complete Trees Three complete trees: Which trees are full? Only tree c is full

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 13 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 13 Implementing Trees An obvious choice for implementing trees is a linked structure Array-based implementations are the less obvious choice, but are sometimes useful Let's first look at the strategy behind two array-based implementations

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 14 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 14 Computed Child Links For full or complete trees, can use an array to represent a tree For a binary tree with any element stored in position n, the element’s left child is stored in array position (2n+1) the element’s right child is stored in array position (2*(n+1)) If the represented tree is not complete or relatively complete, this approach can waste large amounts of array space

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 15 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 15 Simulated Child Links Each element of the array is an object that stores a reference to the tree element and the array index of each child This approach is modeled after the way operating systems manage memory Array positions are allocated on a first-come, first-served basis

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 16 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 16 Tree Traversals For linear structures, the process of iterating through the elements is fairly obvious (forwards or backwards) For non-linear structures like a tree, the possibilities are more interesting Let's look at four classic ways of traversing the nodes of a tree All traversals start at the root of the tree Each node can be thought of as the root of a subtree

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 17 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 17 Tree Traversals Preorder: visit the root, then traverse the subtrees from left to right Inorder: traverse the left subtree, then visit the root, then traverse the right subtree Postorder: traverse the subtrees from left to right, then visit the root Level-order: visit each node at each level of the tree from top (root) to bottom and left to right

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 18 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 18 Tree Traversals Preorder:A B D E C Inorder:D B E A C Postorder:D E B C A Level-Order:A B C D E

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 19 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 19 Tree Traversals Recursion simplifies the implementation of tree traversals Preorder (pseudocode): Visit node Traverse (left child) Traverse (right child) Inorder: Traverse (left child) Visit node Traverse (right child)

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 20 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 20 Tree Traversals Postorder: Traverse (left child) Traverse (right child) Visit node A level-order traversal is more complicated It requires the use of extra structures (such as queues and/or lists) to create the necessary order

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 21 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 21 A Binary Tree ADT

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 22 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 22 A Binary Tree ADT

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 23 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 23 public interface BinaryTreeADT { public T getRootElement(); public boolean isEmpty(); public int size(); public boolean contains(T targetElement); public T find(T targetElement); public String toString(); public Iterator iterator(); public Iterator iteratorInOrder(); public Iterator iteratorPreOrder(); public Iterator iteratorPostOrder(); public Iterator iteratorLevelOrder(); } A Binary Tree ADT

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 24 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 24 Expression Trees An expression tree is a tree that shows the relationships among operators and operands in an expression An expression tree is evaluated from the bottom up

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 25 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 25 Expression Tree Evaluation Let's look at an example that creates an expression tree from a postfix expression and then evaluates it This is a modification of an earlier solution It uses a stack of expression trees to build the complete expression tree

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 26 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 26 Building an Expression Tree Input in Postfix: 5 3 – 4 * 9 +

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 27 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 27 Building an Expression Tree Input in Postfix: 5 3 – 4 * 9 +

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 28 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 28 Decision Trees A decision tree is a tree whose nodes represent decision points, and whose children represent the options available The leaves of a decision tree represent the possible conclusions that might be drawn A simple decision tree, with yes/no questions, can be modeled by a binary tree Decision trees are useful in diagnostic situations (medical, car repair, etc.)

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 29 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 29 Decision Trees A simplified decision tree for diagnosing back pain:

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 30 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 30 public DecisionTree(String filename) throws FileNotFoundException { File inputFile = new File(filename); Scanner scan = new Scanner(inputFile); int numberNodes = scan.nextInt(); scan.nextLine(); int root = 0, left, right; List > nodes = new java.util.ArrayList >(); for (int i = 0; i < numberNodes; i++) nodes.add(i,new LinkedBinaryTree (scan.nextLine())); while (scan.hasNext()) { root = scan.nextInt(); left = scan.nextInt(); right = scan.nextInt(); scan.nextLine(); nodes.set(root, new LinkedBinaryTree ((nodes.get(root)).getRootElement(), nodes.get(left), nodes.get(right))); } tree = nodes.get(root); } Trees can be written to or read from a File

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 31 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 31 Implementing Binary Trees with Links Now let's explore an implementation of a binary tree using links The LinkedBinaryTree class holds a reference to the root The BinaryTreeNode class represents each node, with links to a possible left and/or right child

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 32 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 32 The BinaryTreeNode class represents each node, with links to a possible left and/or right child public class BinaryTreeNode { protected T element; protected BinaryTreeNode left, right; /** * Creates a new tree leaf node with the specified data. obj the element that will become a part of the new tree node */ public BinaryTreeNode(T obj) { element = obj; left = null; right = null; } Implementing Binary Trees with Links

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 33 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 33 The BinaryTreeNode constructor builds an internal or root node left and/or right child are supplied as parameters. // Creates a new tree node with the specified left and right children public BinaryTreeNode(T obj, LinkedBinaryTree left, LinkedBinaryTree right) { element = obj; if (left == null) this.left = null; else this.left = left.getRootNode(); if (right == null) this.right = null; else this.right = right.getRootNode(); } Binary Trees with Links – Building Trees

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 34 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 34 public BinaryTreeNode getRight() { return right; } public void setRight(BinaryTreeNode node) { right = node; } public BinaryTreeNode getLeft() { return left; } public void setLeft(BinaryTreeNode node) { left = node; } Binary Trees– Child Getters and Setters

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 35 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 35 // Attempts to recursively traverse the maze. public boolean traverse(int row, int column) { boolean done = false; if (maze.validPosition(row, column)) { maze.tryPosition(row, column); // mark this cell as tried if (row == maze.getRows()-1 && column == maze.getColumns()-1) done = true; // the maze is solved else { done = traverse(row+1, column); // down if (!done) done = traverse(row, column+1); // right if (!done) done = traverse(row-1, column); // up if (!done) done = traverse(row, column-1); // left } if (done) // this location is part of the final path maze.markPath(row, column); } return done; } Recall: Traversing a Maze Using Recursion

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 36 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 36 // Rrecursively traverse the maze. public boolean traverse(int row, int column) { // Base Case – Test if reached goal else { traverse(row+1, column ); // down traverse(row, column+1); // right traverse(row-1, column ); // up traverse(row, column-1); // left } Execution Tree for understanding Program Flow traverse(0,0) Execution Tree t (1,0)t (0,1) t(-1,0) t(0,-1) right down up left t (2,0)t (1,1) t(0,0) t(1,-1) right down up left

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 37 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 37 Using Trees to Represent Knowledge - TicTacToe As was seen with LearningPlayer in TicTacToe, Trees can be used to represent and capture knowledge. empty board TicTacToe Game Knowledge Tree X takes Square 1 X takes Square 2X takes Square 9 X O X X X O takes Square 1

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 38 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 38 Key Things to take away: Trees: A tree is a nonlinear structure whose elements form a hierarchy Can be stored in an array using simulated link strategy Trees can be balanced or non-balanced A balanced N-ary tree with m elements has height log n m Four basic tree traversal methods: preorder, inorder, postorder, level order Preorder: visit the node first, then its children left to right Inorder: visit the left child, then the node, then its right child Postorder: visit the children left to right, then visit the node itself Level-Order: visit all nodes in a level left to right, starting with the root Decision Trees can be read from files and used to create an expert system Execution Trees can be used to Describe Recursive program flow Trees can be used to store and update knowledge for training AI programs

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 39 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 39 Binary Search Trees Binary search tree processing Using BSTs to solve problems BST implementations Strategies for balancing BSTs

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 40 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 40 Binary Search Trees A search tree is a tree whose elements are organized to facilitate finding a particular element when needed A binary search tree is a binary tree that, for each node n the left subtree of n contains elements less than the element stored in n the right subtree of n contains elements greater than or equal to the element stored in n This is how finds your websites!

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 41 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 41 How Google finds Websites Web Crawlers search the Internet for new websites Read every webpage and every word HUGE files of data – Petabytes! Data Centers process this data And Update Google Search Trees Every webpage, every day

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 42 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 42 Google and Amazon Data Centers

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 43 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 43 Data Centers – A Closer Look All this just to update some search trees Some VERY BIG search trees! For more info: Dr. Mohamed Hefeeda Big-Data and Multimedia

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 44 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 44 Binary Search Trees To determine if a particular value exists in a tree start at the root compare target to element at current node move left from current node if target is less than element in the current node move right from current node if target is greater than element in the current node We eventually find the target or hit the end of a path (target is not found) How to find node with key value 38?  Start at Root and compare 38 to 45  38 < 45 so go to left subtree  38 > 12 so go to the right  38 > 15 so go to the right again  38 < 42 so go left  38 > 33 so go right  38 found!  Return Object stored at this node

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 45 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 45 Binary Search Trees The particular shape of a binary search tree depends on the order in which the elements are added The shape may also be dependant on any additional processing performed on the tree to reshape it Binary search trees can hold any type of data, so long as we have a way to determine relative ordering Objects implementing the Comparable interface provide such capability

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 46 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 46 Binary Search Trees Process of adding an element is similar to finding an element New elements are added as leaf nodes Start at the root, follow path dictated by existing elements until you find no child in the desired direction Then add the new element

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 47 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 47 Binary Search Trees BST operations:

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 48 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 48 BST Element Removal Removing a target in a BST is not as simple as that for linear data structures After removing the element, the resulting tree must still be valid Three distinct situations must be considered when removing an element 1.Node to remove is a leaf 2.Node to remove has one child 3.Node to remove has two children

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 49 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 49 BST Element Removal Dealing with the situations Node is a leaf: it can simply be deleted Node has one child: the deleted node is replaced by the child Node has two children: an appropriate node is found lower in the tree and used to replace the node Good choice: inorder successor (node that follows in an inorder traversal) The inorder successor is guaranteed not to have a left child Thus, removing the inorder successor to replace the deleted node will result in one of the first two situations (it’s a leaf or has one child)

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 50 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 50 Balancing BSTs As operations are performed on a BST, it could become highly unbalanced (a degenerate tree)

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 51 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 51 Balancing BSTs Text implementation does not ensure the BST stays balanced Other approaches do, such as AVL trees and red/black trees We will explore rotations – operations on binary search trees to assist in the process of keeping a tree balanced Rotations do not solve all problems created by unbalanced trees, but show the basic algorithmic processes that are used to manipulate trees

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 52 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 52 Balancing BSTs A right rotation can be performed at any level of a tree, around the root of any subtree Corrects an imbalance caused by a long path in the left subtree of the left child of the root To correct the imbalance A: Make the left child element of the root the new root element B: Make the former root element the right child element of the new root C: Make the right child of what was the left child of the former root, the new left child of the former root

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 53 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 53 Balancing BSTs A left rotation can be performed at any level of a tree, around the root of any subtree Corrects an imbalance caused by a long path in the right subtree of the left child of the root To correct the imbalance A: Make the right child element of the root the new root element B: Make the former root element the left child element of the new root C: Make the left child of what was the right child of the former root, the new right child of the former root

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 54 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 54 Key Things to take away: Trees – Part 2: CMPT 125/126 focused on introducing trees and tree algorithms Will go into more depth in CMPT225 and beyond A binary search tree is a binary tree with the added properties that: the left child’s key is less than the parent’s key value the right child’s key is more than the parent’s this is a recursive definition which results in maintaining sorted order and allows for O(log m N) searches Trees are used to provide efficient implementations for other collections Trees are critical to making the Internet Searching work

Slides based on Java Foundations 3rd Edition, Lewis/DePasquale/Chase 55 Scott Kristjanson – CMPT 125/126 – SFU Wk12.3 Slide 55 References: 1.J. Lewis, P. DePasquale, and J. Chase., Java Foundations: Introduction to Program Design & Data Structures. Addison-Wesley, Boston, Massachusetts, 3rd edition, 2014, ISBN