分析
- 如果当前结点 root 等于 NULL,则直接返回 NULL
- 如果 root 等于p或者q ,那这棵树一定返回p或者q
- 然后递归左右子树,因为是递归,使用函数后可认为左右子树已经算出结果,用 left和right 表示
- 此时若left为空,那最终结果只要看right;若right 为空,那最终结果只要看left
- 如果left和right 都非空,因为只给了p 和 q 两个结点,都非空,说明一边一个,因此root 是他们的最近公共祖先
- 如果left和right 都为空,则返回空(其实已经包含在前面的情况中了)
时间复杂度是O(n):每个结点最多遍历一次或用主定理,空间复杂度是 O(n):需要系统栈空间
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
if(!root)return NULL;
if(root==p||root==q)return root;
auto left=lowestCommonAncestor(root->left,p,q);
auto right=lowestCommonAncestor(root->right,p,q);
if(!left)return right;
if(!right) return left;
if(right&&left) return root;
return NULL;
}
};