This post is completed by 2 users
|
Add to List |
66. Convert a Sorted Doubly Linked List to Balanced BST
Objective: Given a sorted doubly linked list, convert it into a Balanced binary search tree
Example:
data:image/s3,"s3://crabby-images/ac5a6/ac5a6d303394bfbf06560b94302740c72b108825" alt="DLL TO BST Example"
Approach:
- Get the size of the Doubly Linked list.
- Take left n/2 nodes and recursively construct the left subtree
- Make the middle node as root and assign the left subtree( constructed in step 2) to the root's left.
- Recursively construct the right subtree and link it to the right of the root made in step 3.
- See picture below
data:image/s3,"s3://crabby-images/47cd3/47cd3f08be5046293c322cd5cd58013110ee6099" alt="Doubly Linked List To BST"
data:image/s3,"s3://crabby-images/23dcc/23dccdd53bc7c00b0251d0538334a7e31350b13e" alt="Doubly Linked List TO BST - Output"
Output:
DLL is : 1 2 3 4 5 6 7 8 9 Inorder traversal of contructed BST 1 2 3 4 5 6 7 8 9