Download presentation
Presentation is loading. Please wait.
1
Tirgul 5 AVL trees
2
Binary search trees (reminder)
Each tree node contains a value. For every node, its left subtree contains smaller values and its right subtree contains larger values. The time complexity of a search operation is proportional to the tree’s depth. The good case: If the tree is balanced, then every operation takes O(logn) time. The bad case: The tree might get very unbalanced. For example, when inserting ordered numbers to the tree, the resulting height will be exactly n. Reminder: Insertion is always to a leaf, we go down the tree, deciding to turn left or right by comparing the new value to the node value. Deletion of a non-leaf node is different for two cases: If it has only one son we move the son one level higher, overwriting the node we want to delete. If it has two sons, we overwrite it with the largest value in his left subtree or with the smallest value in his right subtree (this node is deleted using the previous case since it has at most one son).
3
AVL Trees Balanced Trees: After insert and delete operations we “fix” the tree to keep it (almost) balanced. AVL Tree: A binary search tree with the following additional balance property: For any node in the tree, the height of the left and right subtrees can differ by 1 at most. Note that we require this balance property for every node, not just the root.
4
Example 12 12 8 16 8 16 4 10 14 4 10 14 2 6 2 6 An AVL tree 1 Not an AVL tree (look at node 8, 12)
5
AVL trees are “reasonably” balanced
We would like to prove that the “deepest” tree with n nodes still has only logarithmic depth. Another way to look at the same problem is proving that the smallest tree with depth h has size at least ch for some c >1 (in fact in our case c= 1.3) If we prove the second claim, then a tree with n nodes must have at least depth at least log1.3n (otherwise it is a counter example for the second claim.) Let’s try to build the minimal tree with depth h
6
Minimal AVL tree of height h
Sh h-1 Sh-2 h-2 Sh-1 Look at the minimal tree of depth h, denote it Sh Since the root’s height is h, one of its sons’ height must be h-1. From the balance condition, the other son has height either h-1 or h-2. Therefore , in the minimal tree the root has one son with a sub tree of depth h-1 and one son of depth h-2. How do these sub trees look like? They are minimal i.e. they are the minimal trees Sh-1 and Sh-2, respectively.
7
The Maximal Height of an AVL Tree
The smallest AVL tree of depth 1 has 1 node, and the smallest AVL tree of depth 2 has 2 nodes. Therefore we get: Claim: Sh = Sh-1+Sh ( S1 = 1 ; S2 = 2 ) Fact : Sh ≥ 2h/2 Theorem: For any AVL tree with n nodes and height h: h = O(log n). Proof: The proof shows that the number of nodes in exponential in the height, even for the minimal tree. Since exp and log are inverse functions, the height is logarithmic in the number of nodes, therefore the insert is O(log n)
8
A lower bound on Sh We know that Sh = Sh-1+Sh-2+1 ( S1 = 1 ; S2 = 2 )
It is easy to show by induction that Sh≥Sh-1 We shall see by induction on h > 2 that Sh ≥ ( … + 2└ h/2 ┘) Base : S3= 4 ≥ 20+21, S4 = 7 ≥ Sh = Sh-1 + Sh ≥ 2(Sh-2) + 1 (monotonicity) ≥ 2(20+…+ 2└ (h-2)/2 ┘)+1 = (21+…+ 2└ h/2 ┘) + 20. By geometric series some we get that Sh ≥ (2└ h/2 ┘+1- 1 )/(2-1) ≥ 2h/2
9
How to maintain balance
General rule: after an insert or delete operation, we fix all nodes that got unbalanced. Since the height of any subtree has changed by at most 1, if a node is not balanced this means that one son has a height larger by exactly two than the other son. Next we show the four possible cases that cause a height difference of 2. In all figures, marked nodes are unbalanced nodes.
10
(only) Four imbalance cases
k2 k1 Case 1: The left subtree is higher than the right subtree, and this is caused by the left subtree of the left child. Case 4: The symmetric case to case 1 k1 k2 C A B B A C Case 2: The left subtree is higher than the right subtree, and this is caused by the right subtree of the left child. k2 k1 Case 3: The symmetric case to case 2 k1 k2 R R P P Q Q
11
Single Rotation - Fixing case 1
k2 k1 right rotation k1 k2 C B A B C A The rotation takes O(1) time. Notice that the new tree is a legal search tree. For insert - it must be the case that subtree A had been increased, so after the rotation, the tree has height as before the insert. For delete, it must be the case that C had been decreased, so after the rotation, the tree has height shorter by 1. Remark: One may ask, If after insert and the balance operation, the height of the tree does not change, when does the height actually increase ?? The answer: the height changes only when the tree has balance of 0 in all nodes on the path from the root to the newly added leaf (thus no re-balance is needed). So, when balance operation is performed, the height doesn’t change, and when the height changes, the balance remains (without a balance operation).
12
Example (caused by insertion)
12 12 k2 k1 8 16 4 16 k2 k1 C A 4 10 14 2 8 14 B C A B 2 6 1 6 10 1 Notice that the tree height has not changed after the rotation (since it was an insert operation).
13
Single Rotation for Case 4
k1 k2 left rotation k2 k1 A B A B C C
14
Example (caused by deletion)
Deleting X and performing a single rotation: A A B X B B A C C C For the rotation, k1 is node A, and k2 is node B. We make k2 the root, and k1 its left son. Notice that the tree height has changed after the rotation (since it was a delete operation).
15
Fixing case 2 - first try... k2 k1 right rotation k1 k2 C A A C B B Single rotation doesn’t help - the tree is still not balanced! What can we do? Use rotations on k1’s sub tree to reduce case 2 to case 1!
16
Example (caused by insertion)
12 6 16 14 8 4 5 2 10 k3 k1 D B k2 A 12 8 16 14 10 4 6 2 5 k3 k1 D A B k2 k1 12 8 16 14 10 6 4 5 k3 D A B k2 2 Note that above is a good friend of case 1 Left rotation on 4 Right rotation on 8
17
Double Rotation to fix case 2
k3 k3 k2 left rotation on k1 right rotation on k3 k2 k1 k1 k3 k1 k2 D D C B C A A D B C B A Note that the height of B and C is not exactly known and that’s why they are located between the two dashed lines and not on one of them. In an insert operation, one of them is located on the lower line and one on the upper line, in the delete, at least one is located on the lower line (but it is possible that they both are). After insertion - original height (of the root) stays the same.
18
Double Rotation to fix case 3
k1 k2 right rotation on k3 left rotation on k1 k3 k1 k3 k2 A B C D A D B C
19
Insert and delete operations
First, we insert/delete the element, as in a regular binary search tree, and then we re-balance. Observation: only nodes on the path from the root to the node we changed may become unbalanced If we went left from the root, then the right subtree was not changed, thus it remains balanced. This continues when we go down the tree.
20
Insert and delete operations (continued)
After adding/deleting a leaf, start to go up back to the root, and while going up, re-balance every node on the way (if needed). The path is O(log n) long, and each node balance takes O(1), thus the total time for every operation is O(log n). In fact, in the insertion we can do better - after the first balance (when going up), the subtree that was balanced has height as before, so all higher nodes are now balanced again. We can find this node in the pass down to the leaf, so one pass is enough.
21
Delete requires two passes
In more sophisticated balanced trees (like red-black and B-trees), delete also requires one pass. Here this is not the case. For example, deleting X in the following tree: L D M A G Deleting X upsets the balance at `A'. When we rotate (B up, A down) to fix this, the whole of this subtree - which is D's left subtree - gets shorter. This means the balance at `D' is upset. When we fix this with a rotation (G up, D down) This subtree (L's left subtree) gets shorter - the subtree heights at this stage are 4 on the left and 6 on the right. When we rotate to fix this (L down, M up), we will get a 5-5 balance at M - so now it is one shorter and its parent is out of balance. This can propagate right to the top of the tree X B E I C F H J K
22
A note about implementation
In programming exercise 2, you will be required to implement a balanced tree. Converting an algorithm to a real program requires much thought. When done correctly, many bugs are avoided. Important principles: Do it as general as possible, without cut & paste. Although more complicated to design, it will reduce your total work time. Methods should be short and simple. If some method becomes too complicated, you missed something, and this is a sure bug! If there’s time left, you might want to do the following example on the board (numbers are inserted in the order written): 5,2,3,9,7,1,8,6,4,0
23
Common mistakes in THW1
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.