This post is completed by 3 users
|
Add to List |
73. Lowest Common Ancestor in a Binary Search Tree.
Objective: - Find the Lowest Common Ancestor of two given nodes in a Binary Search Tree
What is Lowest Common Ancestor
In a given binary tree, The lowest common ancestor of two nodes n1 and n2 will be a node X such that node X will be the lowest node who has n1 and n2 as its descendants.
Similar Problem: Lowest Common Ancestor in a Binary Tree ( Not Binary Search Tree).
Example:
data:image/s3,"s3://crabby-images/f227b/f227b4069937b0423a2ef63a696e17835b75da40" alt="Lowest-Common-Ancestor-BST"
Input: A binary Search Tree and two nodes n1 and n2.
Appraoch:
- Start will the root.
- If root>n1 and root>n2 then lowest common ancestor will be in left subtree.
- If root<n1 and root<n2 then lowest common ancestor will be in right subtree.
- If Step 2 and Step 3 is false then we are at the root which is lowest common ancestor, return it.
data:image/s3,"s3://crabby-images/6cd5a/6cd5a9755f26c90a5cbccc6e51364d0e9f747a76" alt="LCA-in-Binary-Search-Tree"
Output:
Recursive-Lowest Common Ancestor of Nodes 5 and 14 is : 10 Iterative-Lowest Common Ancestor of Nodes 5 and 14 is : 10