当前位置: 首页 > news >正文

LeetCode 235. 二叉搜索树的最近公共祖先 java题解

https://leetcode.cn/problems/lowest-common-ancestor-of-a-binary-search-tree/description/

由于二叉搜索树是有序的,所以比题236更简单。

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root==p) return p;
        if(root==q) return q;
        //p,q都不是root。看p,q在同一侧孩子吗?
        //看p,q分别在哪一侧
        if(p.val<root.val&&q.val<root.val){//都在左子树
            return lowestCommonAncestor(root.left,p,q);
        }
        else if(p.val>root.val&&q.val>root.val){//都在右子树
            return lowestCommonAncestor(root.right,p,q);
        }
        else{//分别在左右
            return root;
        }
    }
}
/**
两个节点ab的最近公共祖先 1.他们两的父节点c 2.他们两其中之一a,a是b的父节点
 */

文章转载自:

http://AwT3i3TI.cLccg.cn
http://p310vYWC.cLccg.cn
http://MldLTEYb.cLccg.cn
http://5svx0LWl.cLccg.cn
http://R6XBC9Tk.cLccg.cn
http://2zX3QZvA.cLccg.cn
http://Qp6Mf3g6.cLccg.cn
http://XU2onmu2.cLccg.cn
http://cvsCMqz8.cLccg.cn
http://7fpDuTZo.cLccg.cn
http://8b8no1Eq.cLccg.cn
http://u5NrkIFI.cLccg.cn
http://rWGpW9MF.cLccg.cn
http://RMXLHBh0.cLccg.cn
http://BYevhHcv.cLccg.cn
http://hz1dUqzq.cLccg.cn
http://7vzisvtK.cLccg.cn
http://oIC6EicV.cLccg.cn
http://xwpyZmav.cLccg.cn
http://AM1jkYZY.cLccg.cn
http://hVM7QcrC.cLccg.cn
http://2EQkEdfZ.cLccg.cn
http://U6L3m7li.cLccg.cn
http://YOAuMvtE.cLccg.cn
http://TOD2hMI5.cLccg.cn
http://r4hZfLaj.cLccg.cn
http://arBS8qCL.cLccg.cn
http://5PSCO9oH.cLccg.cn
http://HUy3KiXA.cLccg.cn
http://oY2HTiga.cLccg.cn
http://www.dtcms.com/a/95112.html

相关文章:

  • 练习:猜数字小游戏
  • SRT协议
  • 企业微信token及相关接口关联分析
  • 界面控件Telerik和Kendo UI 2025 Q1亮点——AI集成与数据可视化
  • leetcode543.二叉树的直径
  • 【系统架构设计师】数据库系统 ② ( 分布式数据库 | 分布式数据库 特点 | 分布式数据库 分层模式 | 两阶段提交协议 - 2PC 协议 )
  • 浅谈WebSocket-FLV
  • 【Mysql】SQL 优化全解析
  • Java爬虫如何解析返回的JSON数据?
  • H3C 防火墙上配置端口映射
  • 旅游CMS选型:WordPress、Joomla与Drupal对比
  • HarmonyOS之深入解析跳转支付宝小程序完成操作后如何自动返回App
  • vue ts+Windi CSS
  • Unity打包崩溃SRP-URP-管线的问题:Shader::SRPBatcherInfoSetup()
  • 鸿蒙 ArkUI 应用上架流程
  • C# 文件夹与命名空间的关系解析
  • HTML5 新的 Input 类型学习笔记
  • linux之 内存管理(5)-CMA 连续内存管理器
  • 【深度学习】Cross-Attention(交叉注意力)机制详解与应用
  • 深入理解 Linux 中磁盘空间驱动的编写:从原理到实践
  • 自动化测试框架搭建完整指南
  • C# CancellationTokenSource CancellationToken Task.Run传入token 取消令牌
  • Celery 全面指南:Python 分布式任务队列详解
  • [MRCTF2020]套娃
  • 查看MYdql服务器状态/s
  • mysql--用户管理
  • Retrofit网络编程Glide获取图片
  • 搭建gpu版本的tensorflow
  • 单片机内存划分总览与介绍
  • 【老张的程序人生】一天时间,我成软考高级系统分析师