Download presentation
Presentation is loading. Please wait.
1
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.1 TTIT33- Algorithms and optimization Algorithms Lecture 5 Balanced Search Trees, Heaps
2
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.2 Content: Balanced Search Trees –AVL Trees [GT 10.2, LD 7.1] –Multi-way search trees [ GT 10.4, LD 7.2, CL 18.1-2] –Information on B-trees [GT 14.3, LD 7.2, CL 18.1-2] Piority Queues – Heaps [GT 8.1,8.3, LD 9.1, CL 6.1-5]
3
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.3 AVL Trees A BST LeftHeight(v)-RightHeight(v)
4
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.4 Worst AVL Tree A worst AVL tree is a maximally unbalanced AVL tree… …or a tree of a given height with a minimum number of internal nodes (Example: insert 44, 17, 78, 32, 50, 88, 62)
5
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.5 AVL-Tree Insertion – Rebalance…
6
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.6 AVL-Tree Insertion… (Goodrich/Tamassia) How to insert an item with key 50? Perform a LookUp(50) While searching for 50, keep track of last passed node with balance 0 critical node If not found, insert at the leaf where search ended Recompute balance on the way back Check critical node! If balance [-1..1], rebalance! 30 b: 0 20 b: 1 60 b: 0 10 b: 0 40 b: 0 70 b: 0 50 b: 0 40 b: -1 60 b: 1 30 b: -1
7
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.7 AVL-Tree Insertion & Re-balance… Now try an item with key 15... Perform a LookUp(15) While searching for 15, keep track of last passed node with balance 0 critical node If not found, insert at the leaf where search ended Recompute balance on the way back Check critical node! If balance [-1..1], rebalance! 30 b: -1 20 b: 1 60 b: 1 10 b: 0 40 b: -1 70 b: 0 50 b: 0 10 b: -1 20 b: 1 30 b: ? 15 b: 0 20 b: 2
8
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.8 Time to re-balance… 60 b: 1 70 b: 0 50 b: 0 k 15 b: 0 b lm 10 b: -1 a 20 b: 2 c n 30 b: ? 40 b: -1 Label the critical node and its 2 descendants on the path to ”15” as a, b, c, such that a < b < c, in an in-order traversal Re-structure the nodes a, b and c so that b has a and c as children!
9
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.9 Time to re-balance… 60 b: 1 70 b: 0 50 b: 0 15 b: 0 b k 10 b: -1 a 20 b: 2 c n 15 b: 0 b k 10 b: -1 a 20 b: 2 c n 15 b: 0 b k 10 b: -1 a 20 b: 2 c n 15 b: 0 b k 10 b: 0 a 20 b: 0 c n 30 b: ? 40 b: -1 lm Label the critical node and its 2 descendants on the path to ”15” as a, b, c, such that a < b < c, in an in-order traversal Re-structure the nodes a, b and c so that b has a and c as children! Update balance! 30 b: -1
10
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.10 Removal of a node... Same thing, but in reverse! 1.Perform a LookUp and Remove as in an ordinary binary tree 2.Update the balance on the way back to the root 3.If too unbalanced: Re-structure!...but: Label the critical node, the child on the deepest side, and its descendants on the deepest side as a, b, c, such that a < b < c, in an in-order traversal Re-structure as previous Go to #2 and continue update and check towards the root (we may have to re-balance more than once!)
11
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.11 Tri-node restructuring = rotations.... Other authors use left and right rotations: Single left rotation: left part of the sub- tree (a and j) is lowered We have ”rotated (up) b over a”... c b a j k l m c b a jkl m
12
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.12 Double rotations... Two rotations are needed when the nodes to re-balance are placed in a zig-zag pattern... 1.Rotate up b over a 2.Rotate up b over c c b a j k l m c b a j k l m c b a j k lm Note: Labeling of a, b and c same as before!
13
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.13 New approach: relax some condition... AVL-Tree: binary tree, accepts a small unbalance Recall: Full binary tree: nonempty; degree is either 0 or 2 for each node Perfect binary tree: full, all leaves have the same depth Can we build and maintain a perfect tree (if we skip ”binary”) ?? we would always know the worst search time exactly!
14
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.14 (2,3) trees [or (2,4) trees, or ( a,b) -trees…] Previously: A single ”pivot element” If larger we search to the right If smaller we search to the left Now: Multiple pivot elements No. of children = no. of pivot elements + 1 8 5 2 12 5 10 28
15
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.15 (2,3) trees, (2,4) trees, or ( a,b) trees... Each node is either a leaf, or has c children where a c b LookUp works aproximately as before Insert must check that a node does not overflow (then we split the node) Delete must check that a node does not become empty (then we transfer or merge nodes)
16
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.16 Insert in (a,b)-tree where a=2 and b=3 As long as there is room in the child we find, add element to that child... If full, split and push the selected pivot element upwards......may happen repeatedly 10 5 10 Insert(10) 5 10 15 Insert(15) 515 5 Insert(18) 10 515 18 Insert(17) 10 515 17 18 10 17 51518
17
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.17 Delete in a (2,3)-tree Three cases: 1.No constraints are violated by removal 2.A leaf is removed (becomes empty) transfer some other key to that leaf, …ok if we have a sibling with 2+ elements 10 17 51518 30 2535 40 20 10 17 51518 35 3040 20 Delete(25) 30 ?35 40 ? 3035 40 Transfer of 30 and 35
18
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.18 Delete in a (2,3)-tree 2.A leaf is removed (becomes empty) transfer some other key to that leaf, or merge (fuse) it with a neighbor 10 17 51518 35 3040 20 Delete(18) 10 17 515? 10 51517 No pivot ?? Too many children! 10 515 17 35 3040 20
19
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.19 Delete in a (2,3)-tree 3.An internal node becomes empty Root: replace with in-order pred. or succ. repair inconsistencies with suitable merge and transfer operations… 10 517 35 3040 20 Delete(20) 10 5? 35 3040 ? Replace......merge leafs 17 ? 5 10 35 3040 17 Internal underflow......merge nodes 5 103040 17 35
20
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.20 Properties of a (2,3) tree Always a perfect tree A minimal tree of height h will have nodes (it’s a full binary tree with full set of nodes at all levels) A maximal (2,3)-tree will have a branching factor of 3, thus …2 keys in every node Thus the height No of keys in a tree
21
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.21 B-Tree Used to keep an index over external data (e.g. content of a disc) It’s only an (a,b)-tree where a = b/2 We may now choose b so that b-1 references to children (other disc blocks) fit into a single disc block By defining a = b/2 we will always fill up a disc block when two blocks are merged!
22
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.22 ADT Priority Queue: –Linearly ordered set K of keys –We store pairs (as in Dictionary), multiple pairs with same key are allowed. The key denotes priority –Items retrieved by priority: i.e. by the minimal key.
23
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.23 Implementing Priority Queues ”last” leaf This is a complete binary tree! This is also called a HEAP
24
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.24 Updates on a Heap Structure DeleteMin = deletion of the root –Replace root by last leaf –Restore partial order by swaping nodes downwards ”down-heap bubbling” Insert –Insert new node after last leaf –Restore partial ordering by ”up-heap bubbling”
25
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.25 HEAP Properties: size(), minElemenent(): O (1) minElement(), minKey(): O (1) insertItem(), removeMin(): O (log n ) >> HeapSort O (n log n ) sorting algorithm Recall vector representation of BST! A complete binary tree... Compact vector representation Bubble-up and bubble-down have fast implementations
26
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.26 HEAP example – bubble-up after insert(4) We store pairs of in the tree. Recall tree representation in a table: getLeftChild(i) = 2*i+1 getRightChild(i) = 2*i+2...where i is the table index, not the key! In [G/T] the root starts at index 1 and representation is: -getLeft(i) = 2*I -getRight(i) = 2*i+1...in [L/D] the root starts at 0...
27
TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.27 Heap Sort Kinds of heaps : minKey in the root => (Min)Heap maxKey in the root => MaxHeap Heap Sort: input D[0..n] Heapify D => Max Heap worst case O(n log n) For i from 0 to n-1 DeleteMax => put in D[n-i] (worst case O(log n) for restoring heap D[0..i]
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.