Binary Search Tree : Lowest Common Ancestor

Sort by

recency

|

761 Discussions

|

  • + 0 comments

    Oddly enough, my solution implemented the same way in Python as in Java failed test cases 2 and 7 only with Python

  • + 0 comments
        while(r != NULL){
            if(x < r->data && y < r->data)
                r = r->left;
            else if(x > r->data && y > r->data)
                r = r->right;
            else
                break;
        }
        return r;
    }
    
  • + 0 comments

    Solution with commented explanation.

    public static Node lca(Node root, int v1, int v2) { // Write your code here. return recLca(root, v1, v2); } public static Node recLca(Node root, int v1, int v2) { if (root == null) { return null; } if (root.data == v1 || root.data == v2) { return root; } Node leftFind = recLca(root.left, v1, v2); Node rightFind = recLca(root.right, v1, v2); if (leftFind == null || rightFind == null) { return leftFind == null ? rightFind : leftFind; } if (leftFind.data == rightFind.data) { return leftFind; } else{ return root; } }

  • + 0 comments

    My C code 😁😎

    struct node *lca( struct node *root, int v1, int v2 ) {
        while(root != NULL){
            if(v1 < root->data && v2 < root->data){
                root = root->left;
            }else if(v1 > root->data && v2 > root->data){
                root = root->right;
            }else{
                break;
            }
        }
        return root;
    }
    
  • + 0 comments

    **i got this answer from the youtube **

    JAVA EASY Youtbe Solution

    import java.io.; import java.util.*;

    public class Solution {

    public static class Node
    {
        public int data ;
        public Node leftNode;
        public Node rightNode;
        public Node(int data)
        {
            this.data = data;
            this.leftNode = null;
            this.rightNode = null;
    
        }
    }
    
    
    public static Node buildTree(Node root,int data)
    {
        if(root == null)
        {
            root = new Node(data);
            return root;
        }
    
        if(root.data > data)
        {
            root.leftNode = buildTree(root.leftNode, data);
        }
        if(root.data<data)
        {
            root.rightNode = buildTree(root.rightNode, data);
        }
        return root;
    }
    
    public static Node lca(Node root,int a,int b)
    {
        if(root.data < a && root.data < b)
        {
            return lca(root.rightNode,a,b);
        }
        if(root.data > a && root.data > b)
        {
            return lca(root.leftNode,a,b);
        }
        return root;
    }
    
    public static void main(String[] args) {
        /* Enter your code here. Read input from STDIN. Print output to STDOUT. Your class should be named Solution. */
        Scanner sc=  new Scanner(System.in);
            Node root = null;
            int n = sc.nextInt();
            int i=0;
            while(i<n)
            {
                i++;
                int inp = sc.nextInt();
                root = buildTree(root, inp);
            }
            int a,b;
            a=sc.nextInt();b=sc.nextInt();
            Node lcaNode = lca(root, a, b);
            System.out.println(lcaNode.data);
            sc.close();
    
    
    }
    

    }