235. Lowest Common Ancestor of a Binary Search Tree

Given a binary search tree (BST), find the lowest common ancestor (LCA) node of two given nodes in the BST.

According to the definition of LCA on Wikipedia: "The lowest common ancestor is defined between two nodes p and q as the lowest node in T that has both p and q as descendants (where we allow a node to be a descendant of itself)."

Example 1:

复制代码
Input: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 8
Output: 6
Explanation: The LCA of nodes 2 and 8 is 6.

Example 2:

复制代码
Input: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 4
Output: 2
Explanation: The LCA of nodes 2 and 4 is 2, since a node can be a descendant of itself according to the LCA definition.

Example 3:

复制代码
Input: root = [2,1], p = 2, q = 1
Output: 2

Constraints:

  • The number of nodes in the tree is in the range [2, 105].
  • -109 <= Node.val <= 109
  • All Node.val are unique.
  • p != q
  • p and q will exist in the BST.

递归法:

复制代码
class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(root->val>p->val && root->val>q->val){
            return lowestCommonAncestor(root->left,p,q);
        }
        else if(root->val<p->val && root->val<q->val){
            return lowestCommonAncestor(root->right,p,q);
        }
        else return root;
    }
};

注意:

第一步,如果root->val比pq都要大就递归左子树,反之递归右子树

第二步,如果不是上面两种(root就是最近公共祖先)就返回root

迭代:

复制代码
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;
    }
};

注意:

不要忘记最后一行的return NULL,又是被这么简短的迭代感动哭的一天

相关推荐
德先生&赛先生17 分钟前
LeetCode-542. 01 矩阵
算法·leetcode·矩阵
HAH-HAH21 分钟前
【洛谷】P2197【模板】Nim 游戏
算法·游戏
lichkingyang39 分钟前
最近遇到的几个JVM问题
java·jvm·算法
feifeigo1232 小时前
matlab中随机森林算法的实现
算法·随机森林·matlab
躲着人群2 小时前
次短路&&P2865 [USACO06NOV] Roadblocks G题解
c语言·数据结构·c++·算法·dijkstra·次短路
一只鲲3 小时前
56 C++ 现代C++编程艺术5-万能引用
开发语言·c++
心动啊1213 小时前
支持向量机
算法·机器学习·支持向量机
小欣加油3 小时前
leetcode 1493 删掉一个元素以后全为1的最长子数组
c++·算法·leetcode
争不过朝夕,又念着往昔4 小时前
即时通讯项目---网关服务
linux·c++·vscode
蓝风破云4 小时前
C++实现常见的排序算法
数据结构·c++·算法·排序算法·visual studio