[LeetCode][LCR 193]二叉搜索树的最近公共祖先

题目

LCR 193. 二叉搜索树的最近公共祖先

给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。

例如,给定如下二叉搜索树:
root = [6,2,8,0,4,7,9,null,null,3,5]

  • 示例 1:

输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 8

输出: 6

解释: 节点 2 和节点 8 的最近公共祖先是 6。

  • 示例 2:

输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 4

输出: 2

解释: 节点 2 和节点 4 的最近公共祖先是 2, 因为根据定义最近公共祖先节点可以为节点本身。

  • 说明:
    所有节点的值都是唯一的。
    p、q 为不同节点且均存在于给定的二叉搜索树中。

注意:本题与主站 235 题相同:LeetCode - Lowest Common Ancestor of a Binary Search Tree

解法:

  1. 本题给的二叉树为二叉搜索树,当节点值比 root 小,则在 root->left 上,反之则在 root->right 上
  2. 如果都在 root->left 上,则在左子树进行搜索,反之在右子树进行搜索
  3. 如果在 root 两侧,则 root 即为最近公共祖先

cpp 复制代码
class Solution {
public:

    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(p->val > q->val) swap(p, q); // 保证 p 的值小于等于 q 的值

        if(p->val <= root->val && q->val >= root->val) return root; // 如果 p、q 分别在 root 的两侧,说明 root 就是最近公共祖先
        if(q->val < root->val) return lowestCommonAncestor(root->left, p, q); // 如果 p、q 都在 root 的左侧,则递归左子树
        if(p->val > root->val) return lowestCommonAncestor(root->right, p, q); // 如果 p、q 都在 root 的右侧,则递归右子树

        return nullptr; // 默认情况下返回空指针
    }
};
相关推荐
AndrewHZ33 分钟前
【图像处理基石】如何在图像中提取出基本形状,比如圆形,椭圆,方形等等?
图像处理·python·算法·计算机视觉·cv·形状提取
蓝牙先生1 小时前
简易TCP C/S通信
c语言·tcp/ip·算法
2501_941870561 小时前
Python在高并发微服务数据同步与分布式事务处理中的实践与优化
leetcode
2501_941147713 小时前
高并发微服务架构Spring Cloud与Dubbo在互联网优化实践经验分享
leetcode
稚辉君.MCA_P8_Java4 小时前
Gemini永久会员 Java中的四边形不等式优化
java·后端·算法
稚辉君.MCA_P8_Java4 小时前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
无限进步_5 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
Swift社区5 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
逝玄5 小时前
关于图灵停机问题不可判定性证明
算法·计算机科学
低客的黑调6 小时前
为你的项目选择一个适合的[垃圾收集器]
java·jvm·算法