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

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

二叉搜索树的最近公共祖先-力扣 235 题

求二叉搜索树最近公共祖先(祖先也包括自己)

前提:

1.节点值唯一

2.p和q都存在

要点:若 p,q 在 ancestor 的两侧,则 ancestor 就是它们的最近公共祖先

解题思路:

/*
            __ 6 __
           /       \
          2         8
         / \       / \
        0   4     7   9
           / \
          3   5
          比如:2与8的祖先有:2、8、6  而6是公共祖先也是最近的
          4与5的祖先有:4、5、2、6  公共祖先有4 2 6   最近的祖先是4
          我们利用这个结论:待查找节点 p q 在某一节点的两侧,那么此节点就是最近的公共祖先
          举一个特殊案例:4与5的祖先有:4、5、2、6  公共祖先有4 2 6 
          先判断6的两侧是不是4与5 如果不是 就进行下一个祖先两侧是否是4与5
          当然在这里,到后面判断4两侧是否是4与5的时候,我们也可以看作是在两侧 
     */

/*__ 6 __/       \2         8/ \       / \0   4     7   9/ \3   5比如:2与8的祖先有:2、8、6  而6是公共祖先也是最近的4与5的祖先有:4、5、2、6  公共祖先有4 2 6   最近的祖先是4我们利用这个结论:待查找节点 p q 在某一节点的两侧,那么此节点就是最近的公共祖先举一个特殊案例:4与5的祖先有:4、5、2、6  公共祖先有4 2 6 先判断6的两侧是不是4与5 如果不是 就进行下一个祖先两侧是否是4与5当然在这里,到后面判断4两侧是否是4与5的时候,我们也可以看作是在两侧 */
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {TreeNode ancestor = root;//ancestor.val > p.val && ancestor.val > q.val:p和q在当前节点的左边//ancestor.val < p.val && ancestor.val < q.val:p和q在当前节点的右边while (ancestor.val > p.val && ancestor.val > q.val || ancestor.val < p.val && ancestor.val < q.val) {if (ancestor.val > p.val) {//这个时候祖先值要开始靠近p或者qancestor = ancestor.left;} else {ancestor = ancestor.right;}}return ancestor;
}

相关文章:

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

二叉搜索树的最近公共祖先-力扣 235 题 求二叉搜索树最近公共祖先&#xff08;祖先也包括自己&#xff09; 前提&#xff1a; 1.节点值唯一 2.p和q都存在 要点&#xff1a;若 p&#xff0c;q 在 ancestor 的两侧&#xff0c;则 ancestor 就是它们的最近公共祖先 解题思路&…...

LuatOS-SOC接口文档(air780E)-- i2c - I2C操作

常量 常量 类型 解释 i2c.FAST number 高速 i2c.SLOW number 低速 i2c.exist(id) i2c编号是否存在 参数 传入值类型 解释 int 设备id, 例如i2c1的id为1, i2c2的id为2 返回值 返回值类型 解释 bool 存在就返回true,否则返回false 例子 -- 检查i2c1是否存…...

帝国cms改目录后打不开,帝国cms改目录生成后还是404

帝国CMS更改了网站域名或者栏目目录地址信息打不开的解决方法&#xff0c;一起来看看吧&#xff1a; 很多的小伙伴们&#xff0c;改了后台的系统设置里面的网站地址或者栏目目录地址&#xff0c;信息页就打不开的解决方法如下&#xff1a; 后台>系统>数据更新>更新信…...

计算机毕业设计选什么题目好?springboot智慧养老中心管理系统

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…...

创建一个基本的win32窗口

1.建立一个窗口的基本步骤 &#xff08;1&#xff09;向系统注册一个窗体类 &#xff08;2&#xff09;根据窗体类创建窗口 &#xff08;3&#xff09;进入消息循环 2.程序结构 (1)主函数的输入参数 int WINAPI WinMain( HISTANCE hInstance,//当前窗口的句柄 HINSTANCE hPr…...

如何在 Spring Boot 中使用 WebSocket

在Spring Boot中使用WebSocket构建实时应用 WebSocket是一种用于实现双向通信的网络协议&#xff0c;它非常适合构建实时应用程序&#xff0c;如在线聊天、实时通知和多人协作工具。Spring Boot提供了对WebSocket的支持&#xff0c;使得在应用程序中集成WebSocket变得非常容易…...

ubuntu2023装完显卡驱动和CUDA CUDNN开机只有下划线闪烁

解决方法 网上很多方案&#xff0c;如Ubuntu开机后卡死只有左上角有一个下划线不停闪烁_ubuntu开机左上角横杠一直闪-CSDN博客&#xff0c;原因是显卡驱动和系统内核不兼容&#xff0c;解决方案是CtrlAltF2打开tty模式进行问题检查 但是我CtrlAltF2完全没反应。 于是&#xf…...

MySQL三种安装方法(yum安装、编译安装、二进制安装)

mysql安装 一、yum安装方式二、编译安装方式三、二进制安装方式 切记&#xff1a;一定要关闭防火墙和selinux&#xff01;&#xff01;&#xff01; 服务器配置&#xff1a;2C4G即可&#xff0c;一台 一、yum安装方式 mysql的官方网站&#xff1a;www.mysql.com 中文官网&…...

《视觉 SLAM 十四讲》第 7 讲 视觉里程计1 【如何根据图像 估计 相机运动】【特征点法】

github源码链接V2 文章目录 第 7 讲 视觉里程计17.1 特征点法7.1.1 特征点7.1.2 ORB 特征FAST 关键点 ⟹ \Longrightarrow ⟹ Oriented FASTBRIEF 描述子 7.1.3 特征匹配 7.2 实践 【Code】本讲 CMakeLists.txt 7.2.1 使用 OpenCV 进行 ORB 的特征匹配 【Code】7.2.2 手写 O…...

9. 一个SpringBoot项目运行

新手如何运行一个SpringBoot项目 1.SpringBoot项目运行 新创建的SpringBoot项目如何运行 2.启动lombok注解 点击该按钮&#xff0c;启动lombok注解支持 3.展示说明...

如何实现chatGPT批量问答,不用token

一、背景 因为需要批量提取一本教材里的概念做成知识图谱&#xff0c;想用chatGPT做概念提取。 调用api&#xff1f;别想了… 免费帐户的api慢得一批于是想用模仿人类交互的方法来调用&#xff0c;本来想用pyautogui的&#xff0c;但是主要是与浏览器交互&#xff0c;还是用s…...

Arduino驱动LIS2DH三轴加速度传感器(惯性测量传感器篇)

目录 1、传感器特性 2、硬件原理图 3、控制器和传感器连线图 4、驱动程序 LIS2DH加速度计相对传统的ADXL345在稳定性以及功耗上都有一定的优化,低功耗模式下仅为2μA(普通模式11μA),并且最高支持5.3KHz输出频率,拥有2g/4g/8g/16g四档可选量程&...

B 开组会(可持久线段树+树剖) 武汉大学2023年新生程序设计竞赛(同步赛)

其实题目就是每次询问一个节点 在这个节点的基础上往下继续遍历t的深度&#xff0c;在这个遍历的过程中找一个最大值就行了 其实这个题目数据非常水&#xff0c;直接暴力就可以过了 下面是别人过的代码 #include<bits/stdc.h> using namespace std; const int mxn5e…...

vue的axios方法

Axios是Vue.js推荐使用的一个基于Promise的HTTP库&#xff0c;用于浏览器和Node.js中发送HTTP请求。它可以让我们更容易地与后端进行数据交互。 以下是Axios的基本用法&#xff1a; 安装Axios 在Vue项目中&#xff0c;可以使用npm来安装Axios&#xff1a; npm install axio…...

gitlab docker部署,备份,恢复。附踩坑记录

本次安装在CentOS7下进行 1、安装yum 检查是否已经安装yum yum --version如果未安装 sudo yum install -y yum-utils添加镜像源&#xff1a; 国外镜像源&#xff1a;yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo阿里镜像源&am…...

2023品牌新媒体矩阵营销洞察报告:流量内卷下,如何寻找增长新引擎?

近年来&#xff0c;随着移动互联网的发展渗透&#xff0c;短视频、直播的兴起&#xff0c;新消费/新零售、兴趣电商/社交电商等的驱动下&#xff0c;布局线上渠道已成为绝大多数品牌的必然选择。 2022年&#xff0c;越来越多的品牌加入到自运营、自播的行列中&#xff0c;并且从…...

HarmonyOS/OpenHarmony原生应用-ArkTS万能卡片组件Toggle

组件提供勾选框样式、状态按钮样式及开关样式。该组件从API Version 8开始支持。 仅当ToggleType为Button时可包含子组件。 一、接口 Toggle(options: { type: ToggleType, isOn?: boolean }) 从API version 9开始&#xff0c;该接口支持在ArkTS卡片中使用。 参数: Toggle…...

redis,mongoDB,mysql,Elasticsearch区别

Redis&#xff1a; Redis是一种高性能键值存储数据库&#xff0c;基于内存操作&#xff0c;支持数据持久化&#xff0c;支持数据类型丰富灵活&#xff0c;如字符串、哈希、列表、集合、有序集合等。Redis还提供了订阅/发布、事务、Lua脚本、主从同步等功能&#xff0c;适用于访…...

什么是软件测试架构师?

软件测试架构师是一个新职位&#xff0c;但确实是一个非常必要的职位&#xff0c;主要有几点&#xff1a; 1. 根据V模型、广义测试概念等&#xff0c;(静态)测试的越早&#xff0c;发现缺陷越早&#xff0c;越有利于产品的质量、加快产品开发周期、降低企业的成本。更重要预防…...

安科瑞ARB5系列弧光保护装置,智能电弧光保护,保障用电安全

安科瑞虞佳豪壹捌柒陆壹伍玖玖零玖叁 什么是弧光 电弧是放电过程中发生的一种现象&#xff0c;当两点之间的电压超过其工频绝缘强度极限时就会发生。当适当的条件出现时&#xff0c;一个携带着电流的等离子产生&#xff0c;直到电源侧的保护设备断开才会消失。空气在通常条件…...

技术指南|USB接口全解析:从Type-A到Type-C的演变与应用

1. USB接口的前世今生&#xff1a;从Type-A到Type-C的进化之路 记得我第一次接触电脑时&#xff0c;那个蓝色的USB接口让我印象深刻。当时只知道它叫"USB"&#xff0c;后来才知道那是Type-A接口。20多年过去&#xff0c;USB接口已经经历了翻天覆地的变化。从最初的T…...

从无线通信到国防测试:基于6U VPX国产载板的快速原型开发实战

6U VPX国产载板在高性能实时处理系统中的实战应用 在无线通信、国防电子和测试测量等对实时性要求极高的领域&#xff0c;系统架构师们常常面临一个核心挑战&#xff1a;如何快速搭建一个既能处理复杂算法又能满足严苛环境要求的硬件验证平台。传统方案往往需要在性能、灵活性和…...

BepuPhysics2多线程架构解密:如何充分利用现代CPU实现并行物理仿真

BepuPhysics2多线程架构解密&#xff1a;如何充分利用现代CPU实现并行物理仿真 【免费下载链接】bepuphysics2 Pure C# 3D real time physics simulation library, now with a higher version number. 项目地址: https://gitcode.com/gh_mirrors/be/bepuphysics2 BepuPh…...

【JavaSE-网络部分06】TCP 纯高性能优化机制:延迟应答・捎带应答【传输层】

上一期咱们把TCP稳如泰山的三大核心机制——滑动窗口、流量控制、拥塞控制彻底盘明白了&#x1f4da;。 这三者强强联手&#xff0c;既守住了可靠传输的底线&#xff0c;又大幅提升传输效率&#xff0c;让数据既稳又快地跑在网络里。 但TCP对性能的“抠搜”可不止于此&#x1f…...

OFA-Image-Caption模型解析:从卷积神经网络到跨模态理解的架构揭秘

OFA-Image-Caption模型解析&#xff1a;从卷积神经网络到跨模态理解的架构揭秘 最近几年&#xff0c;AI在“看图说话”这件事上进步飞快。你可能见过一些工具&#xff0c;上传一张照片&#xff0c;它就能自动生成一段描述。这背后&#xff0c;图像描述生成技术是关键。今天咱们…...

Phi-4-mini-reasoning加速深度学习:卷积神经网络(CNN)模型设计与调优实战

Phi-4-mini-reasoning加速深度学习&#xff1a;卷积神经网络&#xff08;CNN&#xff09;模型设计与调优实战 1. 引言&#xff1a;当AI开始设计AI 在图像分类任务中&#xff0c;我们常常陷入这样的困境&#xff1a;面对海量的网络结构选择和超参数组合&#xff0c;即使是有经…...

Kandinsky-5.0-I2V-Lite-5s多风格测试:卡通、写实、水墨画生成效果对比

Kandinsky-5.0-I2V-Lite-5s多风格测试&#xff1a;卡通、写实、水墨画生成效果对比 1. 开场&#xff1a;当静态艺术遇见动态魔法 想象一下&#xff0c;你珍藏的卡通插画突然活了过来&#xff0c;水墨画中的山水开始流动&#xff0c;写实照片里的场景有了生命。这正是Kandinsk…...

RexUniNLU开源模型实战:400MB模型在A10/A100/T4不同GPU上的适配

RexUniNLU开源模型实战&#xff1a;400MB模型在A10/A100/T4不同GPU上的适配 1. 引言 你是否遇到过这样的困扰&#xff1a;想要使用强大的自然语言理解模型&#xff0c;但动辄几十GB的大模型让部署变得困难重重&#xff1f;或者你的GPU显存有限&#xff0c;无法运行那些"…...

FireRedASR Pro代码详解:从音频预处理到文本后处理全流程

FireRedASR Pro代码详解&#xff1a;从音频预处理到文本后处理全流程 1. 引言 如果你对语音识别感兴趣&#xff0c;想知道一段音频是怎么变成文字的&#xff0c;那么这篇文章就是为你准备的。我们这次不聊怎么用现成的工具&#xff0c;而是直接打开一个叫FireRedASR Pro的语音…...

CentOS 7系统下PyTorch 2.8深度学习镜像的部署与性能调优指南

CentOS 7系统下PyTorch 2.8深度学习镜像的部署与性能调优指南 1. 引言 在深度学习领域&#xff0c;PyTorch已经成为最受欢迎的框架之一。对于需要在企业级CentOS 7生产环境中部署PyTorch 2.8的开发者来说&#xff0c;一个优化良好的环境可以显著提升模型训练和推理的效率。本…...