题目
解题思路
- 结点root不存在,直接返回null;
- 结点root等于p或者q,返回root;
- 分别递归左右子树;
- 左子树为空,返回右子树;右子树为空,返回左子树;
- 都不为空,返回root;
- 都为空,返回null(等同于1)。
解题代码:
class Solution {
public:
TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q)
{
if(root==NULL)
return NULL;
if(root==p||root==q)
return root;
TreeNode*left = lowestCommonAncestor(root->left,p,q);
TreeNode*right = lowestCommonAncestor(root->right,p,q);
if(left==NULL)
return right;
else if(right==NULL)
return left;
else if(left!=NULL&&right!=NULL)
return root;
else
return NULL;
}
};
执行情况: