/
AVL Trees 1 AVL Trees AVL Trees 1 AVL Trees

AVL Trees 1 AVL Trees - PowerPoint Presentation

giovanna-bartolotta
giovanna-bartolotta . @giovanna-bartolotta
Follow
342 views
Uploaded On 2020-01-30

AVL Trees 1 AVL Trees - PPT Presentation

AVL Trees 1 AVL Trees 6 3 8 4 v z AVL Trees 2 AVL Tree Definition Adelson Velsky and Landis binary search tree balanced each internal node v the heights of the children of v can differ by at most 1 ID: 774205

Share:

Link:

Embed:

Download Presentation from below link

Download Presentation The PPT/PDF document "AVL Trees 1 AVL Trees" is the property of its rightful owner. Permission is granted to download and print the materials on this web site for personal, non-commercial use only, and to display it on your personal computer provided you do not modify the materials and that you retain all copyright notices contained in the materials. By downloading content from our website, you accept the terms of this agreement.


Presentation Transcript

AVL Trees 1 AVL Trees 6 3 8 4 v z

AVL Trees 2 AVL Tree Definition Adelson- Velsky and Landis binary search tree balanced each internal node v the heights of the children of v can differ by at most 1 An example of an AVL tree where the heights are shown next to the nodes

AVL Trees 3 Height of an AVL Tree Fact : The height of an AVL tree storing n keys is O(log n). Proof (by induction): n(h): the minimum number of internal nodes of an AVL tree of height h. n(1) = 1 and n(2) = 2For n > 2, an AVL tree of height h contains the root node, one AVL subtree of height n-1 and another of height n-2.That is, n(h) = 1 + n(h-1) + n(h-2) Knowing n(h-1) > n(h-2), we get n(h) > 2n(h-2). Son(h) > 2n(h-2), n(h) > 4n(h-4), n(h) > 8n(n-6), … (by induction), n(h) > 2in(h-2i) Solving the base case we get: n(h) > 2 h/2 - 1 Taking logarithms: h < 2log n(h) +2Thus the height of an AVL tree is O(log n) 3 4 n(1) n(2)

AVL Trees 4 Insertion Insertion is as in a binary search tree Always done by expanding an external node. Insert 54: 44 17 78 32 50 88 48 62 54 w b=x a=y c=z 44 17 78 32 50 88 48 62 before insertion after insertion

AVL Trees 5 Insertion Insertion is as in a binary search tree Always done by expanding an external node. Insert 54: 44 17 78 32 50 88 48 62 54 w b=x a=y c=z 44 17 78 32 50 88 48 62 before insertion after insertion Imbalance Node z Insert Node w

AVL Trees 6 Overview of 4 Cases of Trinode Restructuring 2 4 6 6 2 4 6 4 2 2 6 4 2 6 4 Case 1 Case 2 Case 3 Case 4 z -> y -> x ->

Rotation operationAVL Trees7With a linked structureConstant number of updatesO(1) timeConsider subTree points to y and we also have x and yy.left = x.rightx.right = ysubTree = x

AVL Trees 8 Trinode Restructuring: Case 1 Single Rotation: Keys: a < b < c Nodes: z is not balanced, y is child, x is grandchild on the “trouble” path Not balanced at a, the smallest key x has the largest key cResult: middle key b at the top

AVL Trees 9 Example for Case 1 Case 1 T0 T1 T2 T3 T0 T1T2 T3 2 6 4 2 6 4 z y x

AVL Trees 10 Trinode Restructuring: Case 2 Single Rotation:Not balanced at c, the largest keyx has the smallest key aResult: middle key b at the top Keys: a < b < c Nodes: z is not balanced, y is child, x is grandchild on the “trouble” path T 3 T 2 T 1 T 0 a = x b = y c = z T 0 T 1 T 2 T 3 a = x b = y c = z single rotation

AVL Trees 11 Example for Case 2 Case 2 T0 T1 T2 T3 T0 T1T2 T3 6 2 4 2 6 4 z y x

AVL Trees 12 Trinode Restructuring: Case 3 double rotation: Keys: a < b < c Nodes: z is not balanced, y is child, x is grandchild on the “trouble” path Not balanced at a, the largest key x has the middle key bx is rotated above y x is then rotated above z Result: middle key b at the top

AVL Trees 13 Example for Case 3 Case 3 T0 T1 T2 T3 T0 T1T2 T3 T0 T1 T2 T3 2 6 4 2 6 4 2 4 6 z y x

AVL Trees 14 Trinode Restructuring: Case 4 double rotationNot balanced at c, the largest key x has the middle key b x is rotated above yx is then rotated above xResult: middle key b at the top Keys: a < b < c Nodes: z is not balanced, y is child, x is grandchild on the “trouble” path T 0 T0 T1 T2 T3 T1 T2T3

AVL Trees 15 Example for Case 4 Case 4 T0 T1 T2 T3 T0 T1 T3 T2 T1 T0 T2T3 6 2 4 2 6 4 6 4 2 z y x

AVL Trees 16 Insert 54 ( Case 3 or 4?) 88 44 17 78 32 50 48 62 2 4 1 1 2 2 3 1 54 1 T 0 T 1 T 2 T 3 x y z unbalanced... ...balanced T 1 88 44 17 78 32 50 48 62 2 5 1 1 3 4 2 1 54 1 T 0 T 2 T 3 x y z Draw the double rotation

AVL Trees 17 Overview of 4 Cases of Trinode Restructuring 2 4 6 6 2 4 6 4 2 2 6 4 2 6 4 Case 1 Case 2 Case 3 Case 4 z -> y -> x -> Case i mbalance node z child y Rotation 1 Smallest key (a) Middle key (b) Single: left on node z 2 Largest key (c) Middle key (b) Single: right on node z 3 Smallest key (a) Largest key (c) Double: righ t on child y , left on node z 4 Largest key (c) Smallest key (a) Double: left on child y , right on node z

AVL Trees 18 Removal Removal begins as in a binary search tree the node removed will become an empty external node. Its parent, w, may cause an imbalance. Remove 32, imbalance at 44 44 17 78 32 50 88 48 62 54 44 17 78 50 88 48 62 54 before deletion of 32 after deletion

AVL Trees 19 Rebalancing after a Removal z = first unbalanced node encountered while travelling up the tree from w. y = child of z with the larger height, x = child of y with the larger height trinode restructuring to restore balance at z—Case 1 in example 44 17 78 50 88 48 62 54 w c=x b=y a=z 44 17 78 50 88 48 62 54

AVL Trees 20 Rebalancing after a Removal this restructuring may upset the balance of another node higher in the tree c ontinue checking for balance until the root of T is reached 44 17 78 50 88 48 62 54 w c=x b=y a=z 44 17 78 50 88 48 62 54

Balanced treeAVL Trees21 20 1 30 60 50 70 80 55 35 40 45 10

Delete 80AVL Trees22 20 1 30 60 50 70 80 55 35 40 45 10

Not balanced at 70AVL Trees23 20 1 30 60 50 70 55 35 40 45 10

Single rotationAVL Trees24 20 1 30 55 50 60 70 35 40 45 10

Anything wrong?AVL Trees25 20 1 30 55 50 60 70 35 40 45 10

Not balanced at 50!AVL Trees26 20 1 30 55 50 60 70 35 40 45 10

AVL Trees 27 AVL Tree Performance n entries O(n) space A single restructuring takes O(1) timeusing a linked-structure binary tree Operation Worst -case Time Complexity Get/searchO(log n) Up to height log nPut/insert O(log n)O(log n): searching & restructuringRemove/delete O(log n) O(log n): searching & restructuring up to height log n

AVL Treesbalanced Binary Search Tree (BST)Insert/delete operations include rebalancing if neededWorst-case time complexity: O(log n)expected O(log n) for skip listsNo duplicated keys in skip listsNo moving a bunch of keys in sorted arrayAVL Trees28