题解 | #在二叉树中找到两个节点的最近公共祖先#

递归实现

/*
 * function TreeNode(x) {
 *   this.val = x;
 *   this.left = null;
 *   this.right = null;
 * }
 */

/**
 * 
 * @param root TreeNode类 
 * @param o1 int整型 
 * @param o2 int整型 
 * @return int整型
 */
function lowestCommonAncestor( root ,  o1 ,  o2 ) {
   if(!root) return -1
   if(root.val===o1 || root.val == o2){
       return root.val
   }
    let left = lowestCommonAncestor(root.left,o1,o2)
    let right = lowestCommonAncestor(root.right,o1,o2)
//     如果在左子树中o1和o2都没找到,则肯定在其右子树中,右子树遍历到的那个节点就是最近公共祖先
    if(left == -1){
        return right
    }else if(right == -1){
// 同样如果在右子树中没找到o1和o2,肯定在其左子树
        return left
    }else{
//         两个都找到了,说明在root的两侧,那么root就是祖先
        return root.val
    }
   
}
module.exports = {
    lowestCommonAncestor : lowestCommonAncestor
};
全部评论

相关推荐

05-29 22:11
门头沟学院 Java
Elastic90:抛开学历造假不谈,这公司的招聘需求也挺怪的,Java开发还要求你有图文识别、移动端开发和c++的经验,有点逆天了。
点赞 评论 收藏
分享
05-09 13:22
门头沟学院 Java
点赞 评论 收藏
分享
07-01 19:00
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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