码迷,mamicode.com
首页 > 其他好文 > 详细

二叉树中任意两个节点的最近公共祖先

时间:2017-10-21 16:30:10      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:treenode   div   没有   return   col   ==   log   code   最近公共祖先   

public class Solution {  
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {  
        //发现目标节点则通过返回值标记该子树发现了某个目标结点  
        if(root == null || root == p || root == q) return root;  
        //查看左子树中是否有目标结点,没有为null  
        TreeNode left = lowestCommonAncestor(root.left, p, q);  
        //查看右子树是否有目标节点,没有为null  
        TreeNode right = lowestCommonAncestor(root.right, p, q);  
        //都不为空,说明做右子树都有目标结点,则公共祖先就是本身  
        if(left!=null&&right!=null) return root;  
        //如果发现了目标节点,则继续向上标记为该目标节点  
        return left == null ? right : left;  
    }  
}  

感觉很奇妙

二叉树中任意两个节点的最近公共祖先

标签:treenode   div   没有   return   col   ==   log   code   最近公共祖先   

原文地址:http://www.cnblogs.com/simplepaul/p/7702655.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!