Example of Insertion in AVL Tree
Consider an AVL Tree with following numbers:
50 , 20 , 60 , 10 , 8 , 15 , 32 , 46 , 11 , 48
Step 1: Insert 50
data:image/s3,"s3://crabby-images/38410/38410c1a286b14741ab79253bf8804e47421cdb3" alt="Step 1"
Step 2: Insert 20
As 20 < 50, so insert 20 in 50’s left sub tree.
data:image/s3,"s3://crabby-images/2058f/2058f15b430e0394dbf69df0c4c6f286894cc854" alt="Step 2"
Step 3: Insert 60
As 60 > 50, so insert 60 in 50’s right sub tree.
data:image/s3,"s3://crabby-images/7aac3/7aac3e2cb8ed4b4af8d2efed03217c0e8d9acd76" alt="Step 3"
Step 4: Insert 10
- As 10 < 50, so insert 10 in 50’s left sub tree.
- As 10 < 20, so insert 10 in 20’s left sub tree.
data:image/s3,"s3://crabby-images/e9e78/e9e78575d5053b0cd41666ea91670065a16c6c9a" alt="Step 4"
Step 5: Insert 8
- As 8 < 50, so insert 8 in 50’s left sub tree.
- As 8 < 20, so insert 8 in 20’s left sub tree.
- As 8 < 10, so insert 8 in 10’s left sub tree.
data:image/s3,"s3://crabby-images/78187/78187078dd8a4eafeefc2c1aa306f36d1615bc62" alt="Step 5"
To balance the tree,
- Find the first imbalanced node on the path from the newly inserted node (node 8) to the root node.
- The first imbalanced node is node 20.
- Now, count three nodes from node 20 in the direction of leaf node.
- Then, use AVL tree rotation to balance the tree.
data:image/s3,"s3://crabby-images/f82a4/f82a4f3a1b20d016a0edecb769a318ca76029e3a" alt=""
Step 6: Insert 15
- As 15 < 50, so insert 15 in 50’s left sub tree.
- As 15 > 10, so insert 15 in 10’s right sub tree.
- As 15 < 20, so insert 15 in 20’s left sub tree.
data:image/s3,"s3://crabby-images/62f5b/62f5bb9ace3622092e04d496f0532cc385ac107f" alt="Step 6"
To balance the tree,
- Find the first imbalanced node on the path from the newly inserted node (node 15) to the root node.
- The first imbalanced node is node 50.
- Now, count three nodes from node 50 in the direction of leaf node.
- Then, use AVL tree rotation to balance the tree.
data:image/s3,"s3://crabby-images/5157a/5157a6e01f3e6a3b919191136872a9bee23fde85" alt=""
Step 7: Insert 32
- As 32 > 20, so insert 32 in 20’s right sub tree.
- As 32 < 50, so insert 32 in 50’s left sub tree.
data:image/s3,"s3://crabby-images/2e32d/2e32d22fccef7e95e949e0d2cb3dd3aa1248749c" alt=""
Step 8: Insert 46
- As 46 > 20, so insert 46 in 20’s right sub tree.
- As 46 < 50, so insert 46 in 50’s left sub tree.
- As 46 > 32, so insert 46 in 32’s right sub tree.
data:image/s3,"s3://crabby-images/ccedd/ccedd61ab90a4aca0c24ba9160d5c0af54099998" alt="Step 8"
Step 9: Insert 11
- As 11 < 20, so insert 11 in 20’s left sub tree.
- As 11 > 10, so insert 11 in 10’s right sub tree.
- As 11 < 15, so insert 11 in 15’s left sub tree.
data:image/s3,"s3://crabby-images/46175/46175d093bbbcc2855cc530edfde34116463d82d" alt="Step 9"
Step 10: Insert 48
- As 11 < 20, so insert 11 in 20’s left sub tree.
- As 11 > 10, so insert 11 in 10’s right sub tree.
- As 11 < 15, so insert 11 in 15’s left sub tree.
data:image/s3,"s3://crabby-images/7d18f/7d18f5b6d553f18c4e7393f87c330f04a7c3604c" alt="Step 10"
To balance the tree,
- Find the first imbalanced node on the path from the newly inserted node (node 48) to the root node.
- The first imbalanced node is node 32.
- Now, count three nodes from node 32 in the direction of leaf node.
- Then, use AVL tree rotation to balance the tree.
data:image/s3,"s3://crabby-images/869d4/869d4d62b473252025f6ef1ca78b772c1821250d" alt=""
data:image/s3,"s3://crabby-images/9558c/9558cf6b1f6c965bccf28c3af4aaa4edd8500297" alt=""
For more Data Structures & Algorithms Tutorials Click here