LeetCode 235.二叉搜索树的最近公共祖先
题目链接:https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-search-tree/
题目
解答
递归法
class Solution {
private:
TreeNode* traversal(TreeNode* cur, TreeNode* p, TreeNode* q) {
if(cur == NULL) return NULL;
if(cur->val > p->val && cur->val > q->val) {
TreeNode* left = traversal(cur->left, p, q);
if(left != NULL) {
return left;
}
}
if(cur->val < p->val && cur->val < q->val) {
TreeNode* right = traversal(cur->right, p, q);
if(right != NULL) {
return right;
}
}
return cur;
}
public:
TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
return traversal(root, p, q);
}
};
迭代法
class Solution {
public:
TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
while(root) {
if(root->val > p->val && root->val > q->val) {
root = root->left;
} else if (root->val < p->val && root->val < q->val) {
root = root->right;
} else {
return root;
}
}
return NULL;
}
};