- A balance binary search tree.
- The best search time, that is O(log N) search times
- An AVL tree is defined to be a well-balanced binary search tree in which each of its nodes has the AVL property.
- The AVL property is that the heights of the left and right sub-trees of a node are either equal or if they differ only by 1
data:image/s3,"s3://crabby-images/a760f/a760fca68ff6c5454b8df0ce56627464e89b0487" alt=""
data:image/s3,"s3://crabby-images/9dc33/9dc33667ab8f334e9d632abbe99ee3131876bc99" alt=""
Keeping the Tree Balance
- the height of the right subtree and height of the left subtree for any node cannot differ by more than one.
- This process is usually done through rotation.
- A single counter clockwise rotate will balance it.
- s_ right_rotate() - because it involves the right subtree.
- A single counter clockwise rotate will balance it.
- s_ left_rotate() - because it involves the left subtree.
- A double clockwise rotate will balance it.
- 1st - single clockwise rotation with the parent of the inserted node (this produces the tree in diagram 1)
- 2nd - single counter clockwise rotation on the root
- d_ right_rotate() - because it involves the right subtree.
- A double clockwise rotate will balance it.
- 1st - single counter clockwise rotation with the parent of the inserted node (this produces the tree in diagram 2)
- 2nd - single clockwise rotation with the root.
- d_ left_rotate() - because it involves the left subtree.
Diagram 1
data:image/s3,"s3://crabby-images/fc38e/fc38e89d4cbbcbc4fce63cb6c0c567e441b37c89" alt=""
Diagram 2
data:image/s3,"s3://crabby-images/51631/51631605214d1e1ee3173e899061c27856b1e8cf" alt=""
Diagram 3
data:image/s3,"s3://crabby-images/292ee/292eeb49483f438874ef458bbbaca3c900b29176" alt=""
Diagram 4
data:image/s3,"s3://crabby-images/d718f/d718f8db63300adcd4b9f0d54d085cca083b2d76" alt=""
Example:
Given these data: build an AVL tree.
12 , 10 , 3 , 23 , 11, 14 , 2 , 4 , 1
Click the picture below to see the answer! ^_^
data:image/s3,"s3://crabby-images/229de/229deeb936252eb7be3e19d2038b794b3972b9d7" alt=""
0 comments:
Post a Comment