(1) 如果当前结点 root 等于 NULL,则直接返回 NULL
(2) 如果 root 等于 p 或者 q ,那这棵树一定返回 p 或者 q
(3) 然后递归左右子树,因为是递归,使用函数后可认为左右子树已经算出结果,用 leftNode 和 rightNode 表示
(4) 此时若leftNode为空,那最终结果只要看 rightNode;若 rightNode 为空,那最终结果只要看 leftNode
(5) 如果 leftNode 和 rightNode 都非空,因为只给了 p 和 q 两个结点,都非空,说明一边一个,因此 root 是他们的最近公共祖先
(6) 如果 leftNode 和 rightNode 都为空,则返回空(其实已经包含在前面的情况中了)
class Solution {
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
if(root==p||root==q) return root;
while(root!=null){
TreeNode leftNode=lowestCommonAncestor(root.left,p,q);
TreeNode rightNode=lowestCommonAncestor(root.right,p,q);
if(leftNode!=null&&rightNode!=null)
return root;
else if(leftNode==null){
return rightNode;
}
else return leftNode;
}
return null;
}
}