题目来源:二叉搜索树的最近公共祖先_牛客题霸_牛客网 (nowcoder.com)
描述
给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。
1.对于该题的最近的公共祖先定义:对于有根树T的两个结点p、q,最近公共祖先LCA(T,p,q)表示一个结点x,满足x是p和q的祖先且x的深度尽可能大。在这里,一个节点也可以是它自己的祖先.
2.二叉搜索树是若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值
3.所有节点的值都是唯一的。
4.p、q 为不同节点且均存在于给定的二叉搜索树中。
数据范围:
3<=节点总数<=10000
0<=节点值<=10000
如果给定以下搜索二叉树: {7,1,12,0,4,11,14,#,#,3,5},如下图:
我的代码(参考了答案):
/**
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* };
*/
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param root TreeNode类
* @param p int整型
* @param q int整型
* @return int整型
*/
TreeNode* find_ancestor(TreeNode* root, int p, int q){
if(!root) return nullptr;
if(root->val==p || root->val==q) return root;
TreeNode* left=find_ancestor(root->left, p, q);
TreeNode* right=find_ancestor(root->right, p, q);
if(left==nullptr) return right;
else if(right==nullptr) return left;
else
return root;
}
int lowestCommonAncestor(TreeNode* root, int p, int q) {
// write code here
return find_ancestor(root,p,q)->val;
}
};