Presentation is loading. Please wait.

Presentation is loading. Please wait.

TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.1 TTIT33- Algorithms and optimization Algorithms Lecture 5 Balanced Search.

Similar presentations


Presentation on theme: "TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.1 TTIT33- Algorithms and optimization Algorithms Lecture 5 Balanced Search."— Presentation transcript:

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]


Download ppt "TTIT33 Algorithms and Optimization – DALG Lecture 6 Jan Maluszynski - HT 20066.1 TTIT33- Algorithms and optimization Algorithms Lecture 5 Balanced Search."

Similar presentations


Ads by Google