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

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

http://www.nowcoder.com/practice/e0cc33a83afe4530bcec46eba3325116

/*

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

/** *

  • @param root TreeNode类
  • @param o1 int整型
  • @param o2 int整型
  • @return int整型 */

思路:每个root进递归函数,

先看1.是否有值2.是不是要找的两个节点;

都不是,那就继续找这个root的左、右子树:

左右节点只有其中一个能找到o1或o2,就返回这个左/右节点;

左右节点都能找到,说明这个root就是最近的祖先节点;

都没找到返回null;

function lowestCommonAncestor( root ,  o1 ,  o2 ) {
    //节点为null,则返回nul
    if(!root){
        return null
    }
    //该节点就是o1或o2的位置,就返回root
    if(root.val == o1||root.val == o2) return root.val
    //不是o1 o2的位置,就继续找root的左右子树
    let left = lowestCommonAncestor(root.left,o1,o2);
    let right = lowestCommonAncestor(root.right,o1,o2);
    //
    if(left&&!right){
        return left
    }
    if(right&&!left){
        return right
    }
    if(!right&&!left){
        return null
    }
    return root.val


}
module.exports = {
    lowestCommonAncestor : lowestCommonAncestor
};
全部评论

相关推荐

神哥不得了:神哥来啦~自我评价和校园经历的话可以直接删了,从大厂暑期的话应该没有什么太多问题,应该是能拿到很多大厂面试机会的,就是在面试的时候表示的好一点就行,可以在面试前先把高频top 50的八股多巩固几遍,千万不要看那些假高频八股,这两个项目的话问题不是很大,应该能够帮你找到大厂实习的,算法的话一定要刷起来,因为大厂有些还是比较看重算法的
点赞 评论 收藏
分享
04-02 16:49
门头沟学院 Java
_bloodstream_:我也面了科大讯飞,主管面的时候听说急招人优先考虑能尽快实习的,我说忙毕设,后面就一直没消息了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务