CS 3013 Binary Search Trees.

Slides:



Advertisements
Similar presentations
David Luebke 1 6/1/2014 CS 332: Algorithms Medians and Order Statistics Structures for Dynamic Sets.
Advertisements

Chapter 12 Binary Search Trees
Comp 122, Spring 2004 Binary Search Trees. btrees - 2 Comp 122, Spring 2004 Binary Trees  Recursive definition 1.An empty tree is a binary tree 2.A node.
Analysis of Algorithms CS 477/677 Binary Search Trees Instructor: George Bebis (Appendix B5.2, Chapter 12)
CS 332: Algorithms Binary Search Trees. Review: Dynamic Sets ● Next few lectures will focus on data structures rather than straight algorithms ● In particular,
David Luebke 1 5/4/2015 Binary Search Trees. David Luebke 2 5/4/2015 Dynamic Sets ● Want a data structure for dynamic sets ■ Elements have a key and satellite.
Binary Search Trees Comp 550.
1 abstract containers hierarchical (1 to many) graph (many to many) first ith last sequence/linear (1 to 1) set.
Binary Trees, Binary Search Trees COMP171 Fall 2006.
Universal Hashing When attempting to foil an malicious adversary, randomize the algorithm Universal hashing: pick a hash function randomly when the algorithm.
1.1 Data Structure and Algorithm Lecture 12 Binary Search Trees Topics Reference: Introduction to Algorithm by Cormen Chapter 13: Binary Search Trees.
1 abstract containers hierarchical (1 to many) graph (many to many) first ith last sequence/linear (1 to 1) set.
David Luebke 1 7/2/2015 ITCS 6114 Binary Search Trees.
Analysis of Algorithms CS 477/677 Instructor: Monica Nicolescu.
David Luebke 1 7/2/2015 Medians and Order Statistics Structures for Dynamic Sets.
CS21, Tia Newhall Binary Search Trees (BST) 1.Hierarchical data structure with a single pointer to root node 2.Each node has at most two child nodes (a.
Marc Smith and Jim Ten Eyck
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.
CS 2133: Data Structures Binary Search Trees.
David Luebke 1 9/18/2015 CS 332: Algorithms Red-Black Trees.
Chapter 12. Binary Search Trees. Search Trees Data structures that support many dynamic-set operations. Can be used both as a dictionary and as a priority.
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 SearchTrees [CLRS] – Chap 12. What is a binary tree ? A binary tree is a linked data structure in which each node is an object that contains following.
Binary Search Tree Qamar Abbas.
Red-Black Trees. Review: Binary Search Trees ● Binary Search Trees (BSTs) are an important data structure for dynamic sets ● In addition to satellite.
Binary Search Trees (BST)
Lecture 19. Binary Search Tree 1. Recap Tree is a non linear data structure to present data in hierarchical form. It is also called acyclic data structure.
Mudasser Naseer 1 1/25/2016 CS 332: Algorithms Lecture # 10 Medians and Order Statistics Structures for Dynamic Sets.
Binary Search Trees (BST) Let’s look at some pics …and some code.
CS6045: Advanced Algorithms Data Structures. Dynamic Sets Next few lectures will focus on data structures rather than straight algorithms In particular,
Fundamentals of Algorithms MCS - 2 Lecture # 17. Binary Search Trees.
Binary Search Trees What is a binary search tree?
Non Linear Data Structure
Trees Chapter 15.
Trees Chapter 11 (continued)
Trees Chapter 11 (continued)
BST Trees
UNIT III TREES.
CS 332: Algorithms Red-Black Trees David Luebke /20/2018.
Binary Search Tree (BST)
CS 302 Data Structures Trees.
Trees.
Trees Lecture 12 CS2110 – Fall 2017.
Binary Search Tree Chapter 10.
Lecture 22 Binary Search Trees Chapter 10 of textbook
Data Structures & Algorithm Design
abstract containers sequence/linear (1 to 1) hierarchical (1 to many)
CS200: Algorithms Analysis
ITEC 2620M Introduction to Data Structures
CS 3013 Binary Search Trees.
Lecture 7 Algorithm Analysis
Binary Trees, Binary Search Trees
Ch. 11 Trees 사실을 많이 아는 것 보다는 이론적 틀이 중요하고, 기억력보다는 생각하는 법이 더 중요하다.
Threaded Trees Binary trees have a lot of wasted space: the leaf nodes each have 2 null pointers We can use these pointers to help us in inorder traversals.
Map interface Empty() - return true if the map is empty; else return false Size() - return the number of elements in the map Find(key) - if there is an.
General Trees & Binary Trees
Find in a linked list? first last 7  4  3  8 NULL
Chapter 16 Tree Implementations
Lecture 7 Algorithm Analysis
Chapter 12: Binary Search Trees
CS6045: Advanced Algorithms
Lecture 7 Algorithm Analysis
Binary Trees, Binary Search Trees
Trees Chapter 10.
Chapter 20: Binary Trees.
Binary Search Trees Comp 122, Spring 2004.
Binary Trees, Binary Search Trees
Chapter 11 Trees © 2011 Pearson Addison-Wesley. All rights reserved.
Tree (new ADT) Terminology: A tree is a collection of elements (nodes)
Presentation transcript:

CS 3013 Binary Search Trees

Definition of a Tree A Binary tree is a set T of nodes such that either 1. T is empty or 2. T is partitioned into three disjoint subsets. A single node r, the root Two (possibly empty) sets that are binary trees, called left and right subtrees of r. T T T Tl Tr

Structure of a Tree root struct Node{ int value; Node * left; Node * right; } 5 class Tree{ Node * _root; public: Tree();//constructor Insert(int); Print(); } 4 6 3 10 7 9

Binary Search Trees Binary Search Trees (BSTs) are an important data structure for manipulating dynamically changing data sets. Each node has the following fields: value: an identifying field inducing a total ordering left: pointer to a left child (may be NULL) right: pointer to a right child (may be NULL) p: (sometimes) pointer to a parent node (NULL for root)

Binary Search Trees BST property: Value of nodes in left subtree <= roots value Value of nodes in right subtree > roots value Example: F B H K D A

Inorder Tree Walk What does the following code do? void TreeWalk(Node * tree){ if(tree!=nullptr){ TreeWalk(tree->left); cout<<tree->value<<endl; TreeWalk(tree->right); }} A: prints elements in sorted (increasing) order This is called an inorder tree walk Preorder tree walk: print root, then left, then right Postorder tree walk: print left, then right, then root

Inorder Tree Walk Example: How long will a tree walk take? Prove that inorder walk prints in monotonically increasing order F B H K D A

Operations on BSTs: Search Given a key and a pointer to a node, returns an element with that key or nullptr. This should be private. Why? Node * TreeSearch(Node * ptr, int k){ if (ptr == nullptr)return nullptr; if (ptr->value==k) return ptr; if (k < ptr->value) return TreeSearch(ptr->left, k); else return TreeSearch(ptr->right, k); }

BST Search: Example Search for D and C: F B H K D A

Operations of BSTs: Insert For a non recursive insert Adds an element x to the tree so that the binary search tree property continues to hold The basic algorithm Like the search procedure above Insert x in place of nullptr Use a “trailing pointer” to keep track of where you came from (like inserting into singly linked list)

BST Insert: Example Example: Insert C F B H K D A C

BST class BST class { Node * _tree; InsertAux(Node* & , const int & ) public: BST(){ _root=nullptr;} ~BST(); // Destructor Insert(int v){InsertAux(_root,v);} }

Aux Method’s if a method returns a pointer into the tree then the method cannot be public in this case you need to have two methods one public and one private. the public one calls the private method In main you are only allowed to call the public version.

Recursive Insert in a Class void BST::InsertAux(Node* & tree, const int & item) { if(tree==nullptr) tree=new Node(item); else if (item < tree->value) InsertAux(tree->left, item); InsertAux(tree->right, item); } Note &’s

What happens when you insert the numbers 1,2,3,…,10 into a BST in that order? you insert the numbers 10.9,…,1 Insert these numbers in a BST 5,7,3,1,8,2,6,4 Draw it.

BST Search/Insert: Running Time What is the running time of TreeSearch() or insertAux()? A: O(h), where h = height of tree What is the height of a binary search tree? A: worst case: h = O(n) when tree is just a linear string of left or right children We’ll keep all analysis in terms of h for now Later we’ll see how to maintain h = O(lg n)

BST Destroy the tree BST::~BST(){destroyTree(_root)} void BST::destroyTree(Node *& tree) { if (tree != nullptr;) { destroyTree(tree->left); destroyTree(tree->right); delete tree; tree=nullptr; }

BST Operations: Delete Deletion is a bit tricky 3 cases: x has no children: Remove x x has one child: Splice out x x has two children: Swap the value of x with successor (or predecessor) Perform case 1 or 2 to delete it F B H K D A C Example: delete K or H or B

Delete Algorithm void BST::TreeDelete(Node *& root, int x) { if(root!=nullptr){ Node * tempPtr; Node * predPtr; if(x<root->val)TreeDelete(root->left, x); else if(x>root->val)TreeDelete(root->right, x); else { // we have found it so lets delete it // tree points at it right!? // If No children we just delete it if(root->left==nullptr && root->right==NULL){ delete(root); root=nullptr; // what happens when we return; // return here! important! }

Delete Continued with one child // Check to see if the node to delete has only one child if(root->left==nullptr){ // Then splice in the right side tempPtr=root->right; delete root; root=tempPtr; }else if (root->right==NULL){ // splice left tempPtr=root->left; delete(root); } else // both children exist! so...

Delete Continued with two children // Here root has two children // We first find the successor { tempPtr=root->right; // Go right // and the all the way to the left while(tempPtr->left!=nullptr){ predPtr=tempPtr; tempPtr=tempPtr->left; } root->val=tempPtr->val; // Copy the value up to the root if(root->right==tempPtr)root->right=tempPtr->right; else predPtr->left=tempPtr->right; delete tempPtr; root predPtr tempPtr

BST Operations: Delete Why will case 2 always go to case 0 or case 1? A: because when x has 2 children, its successor is the minimum in its right subtree Could we swap x with predecessor instead of successor? A: yes. Would it be a good idea? A:See the Eppinger paper!!

Sorting With Binary Search Trees Informal code for sorting array A of length n: BSTSort(A) BST t; for(auto v:A) t.TreeInsert(v); t.InorderTreeWalk(root);// prints What will be the running time in the Worst case? Average case?

Left Child Right Sibling Representation K D A C F B H A D H C RCLS format Normal format Really is a binary way to represent an n ary tree. Also each child has a pointer to its parent.

Recursive Traversal of a LCRS Tree LCRST::Traverse(Node * t) { if (t != nullptr) then Traverse(t->child()) If (t->sibling() !=nullptr) then Traverse(t->sibling()) } B H A D H C Here t->child() returns a pointer to the left child and t->sibling() returns a ptr to right child

Algorithm BT->LCRS Format Can you design an algorithm that will convert a binary tree to the left child right sibling format?

Saving a binary search tree in a file We can do this so the tree gets restored to the original shape. How do we do this? save in preorder ! Or we can restore it in a balanced shape save in inorder and ?

Loading a balanced tree from a sorted list readTree(Node *& treePtr,int n) { if (n>0) { // read in the left subtree treePtr=new Node(nullptr,nullptr); readTree(treePtr->left,n/2); cin>> treePtr->val; // read in the right subtree readTree(treePtr->right,(n-1)/2); }

Level Order Traversal F B H K D A How do you perform an level by level traversal? F B H K D A Q.enq(root) While(Q not empty){ x = Q.deq(); Print x; Q.enq(left_child); Q.enq(right_child); } NOTE: This uses a queue as its support data structure

Expression Trees + * + + X 3 Y W 5 W + 5 * X + 3 + Y inorder traversal ((W+5)*X + (3+Y)) with parens How about preorder and postorder traversals?

Problem A preorder traversal of a binary tree produced ADFGHKLPQRWZ and an inorder traversal produced GFHKDLAWRQPZ Draw the binary tree.

Program to Build Tree substr(start, len) 0 1 2 . . . void BuildTree(string in,string post) { char root; int len=in.length(); // NOTE: Last char of postorder traveral is the root of the tree if(len==0)return; root=post[len-1]; cout<<root; // print the root // Search for root in the inorder traversal list int i=0; while(in[i]!=root)i++; // skip to the root // i now points to the root in the inorder traversal // The chars from 0 to i-1 are in the left subtree and // the chars from i+1 to len_in-1 are in the right sub tree. // Process left sub tree BuildTree(in.substr(0,i),post.substr(0,i)); //Process right sub tree BuildTree(in.substr(i+1,len-i-1), post.substr(i,len-i-1)); } 0 1 2 . . . substr(start, len)