CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
- f “binary
search tree” Queries in binary search trees Insertion and deletion Final remarks
Week 5+ Oliver Kullmann Dynamic sets BinaryTrees Trees - - PowerPoint PPT Presentation
CS 270 Algorithms Week 5+ Oliver Kullmann Dynamic sets BinaryTrees Trees Implementing rooted trees Dynamic sets 1 The notion of binary search tree Trees 2 Queries in binary search trees Implementing rooted trees 3
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 the introduction to Part III on using sets on a computer 2 Section 10.4 on implementing rooted trees 3 Sections 12.1, 12.2, 12.3 on binary search trees.
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 Storing S via an array (or a list), SEARCH can be
2 To do faster than this, typically in time O(log(|S|))
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 the root has no parent node 2 a node may have only one child, left or right 3 a leaf has no children.
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 First print out the keys of the left subtree of the root. 2 Then print the key of the root. 3 Finally print out the keys of the right subtree of the root.
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 If the key k′ of the root of T equals k, then return the root. 2 Otherwise, if k ≤ k′ then return the result for the left
3 Otherwise return the result for the right subtree of T.
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 x′ > x (that is (for a linear order) x′ ≥ x and x′ = x), 2 there is no y ∈ M with y > x and y < x′.
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 If x has a right child, then by our definition (and the
2 But what if x has no right child? Perhaps then there is no
3 Considering the example 8 slides ago, we see that the node
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 “Validity” must include that the observable content of
2 However links to parents and children may be altered.
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 If z has no children, then z can be just deleted, and for its
2 If z has only one child, then again z can be just deleted,
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 Hope for randomisation. 2 Or improve the worst-case behaviour, by using more
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
CS 270 Algorithms Oliver Kullmann Dynamic sets Trees Implementing rooted trees The notion
search tree” Queries in binary search trees Insertion and deletion Final remarks
1 Yet we produce a degenerated tree (the worst-case), just
2 This is due to the fact that in the existing inorder sequence
3 One could also insert it into last possible position, always
4 The right thing to do is to do both, in the right mixture!