Leetcode-235: 二叉搜索树的最近公共祖先

题目描述:
给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。

思路
利用二叉搜索树的性质,如果p,q 的值在root的两侧,则直接返回root,如果p,q值都小于root值,那么在root.left中查找。如果p,q值都大于root值,那么在root.right中查找。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root==null)
            return root;
        if(root==p || root==q)
            return root;
        if((root.val-p.val)* (root.val-q.val)<0)
            return root;
        else if(root.val > p.val && root.val >q.val)
            return lowestCommonAncestor(root.left,p,q);
        else if(root.val < p.val && root.val < q.val)
            return lowestCommonAncestor(root.right,p,q);
        return null;
    }
}
全部评论

相关推荐

哈哈哈哈哈哈哈哈哈哈这个世界太美好了
凉风落木楚山秋:毕业出路老师不管,你盖个章他好交差就完事了,等你盖完毕业了就不关他事情了
点赞 评论 收藏
分享
牛客84809583...:举报了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务