代码学习记录18

news2025/1/16 5:32:13

随想录日记part18

t i m e : time: time 2024.03.13



主要内容:今天的主要内容是二叉树的第七部分,主要涉及二叉搜索树的最近公共祖先 ;二叉搜索树的最近公共祖先;删除二叉搜索树中的节点 。

  • 235. 二叉搜索树的最近公共祖先
  • 701.二叉搜索树中的插入操作
  • 450.删除二叉搜索树中的节点


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

题目:

给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。
示例:
请添加图片描述

输入: r o o t = [ 6 , 2 , 8 , 0 , 4 , 7 , 9 , n u l l , n u l l , 3 , 5 ] , p = 2 , q = 8 root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 8 root=[6,2,8,0,4,7,9,null,null,3,5],p=2,q=8
输出: 6 6 6

思路:

递归三部曲如下:

  • 确定递归函数返回值以及参数
TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q)
  • 确定终止条件
if (root == p || root == q) return root;
  • 确定单层递归的逻辑
    1.如果 r o o t . v a l root.val root.val 大于 p . v a l p.val p.val,同时 r o o t . v a l root.val root.val 大于 q . v a l q.val q.val,那么就应该向左遍历(说明目标区间在左子树上)
if (root.val > Math.max(p.val, q.val)) {
	TreeNode left = lowestCommonAncestor(root.left, p, q);
    if (left != null) return left;
}

2.如果 r o o t . v a l root.val root.val 小于 p . v a l p.val p.val,同时 r o o t . v a l root.val root.val 小于 q . v a l q.val q.val,那么就应该向右遍历(说明目标区间在右子树上)

if (root.val < Math.min(p.val, q.val)) {
	TreeNode right = lowestCommonAncestor(root.right, p, q);
	if (right != null) return right;
}

3.最后就是直接返回 r o o t root root
完整代码如下:

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        // 递归出口
        if (root == p || root == q)
            return root;
        // 单层递归逻辑
        if (root.val < Math.min(p.val, q.val)) {
            TreeNode right = lowestCommonAncestor(root.right, p, q);
            if (right != null)
                return right;
        }
        if (root.val > Math.max(p.val, q.val)) {
            TreeNode left = lowestCommonAncestor(root.left, p, q);
            if (left != null)
                return left;
        }
        return root;
    }

}


Topic2二叉搜索树中的插入操作

题目:

给定二叉搜索树( B S T BST BST)的根节点 r o o t root root 和要插入树中的值 v a l u e value value ,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据保证 ,新值和原始二叉搜索树中的任意节点值都不同。
注意: 可能存在多种有效的插入方式,只要树在插入后仍保持为二叉搜索树即可。 你可以返回任意有效的结果 。

请添加图片描述

输入: r o o t = [ 4 , 2 , 7 , 1 , 3 ] , v a l = 5 root = [4,2,7,1,3], val = 5 root=[4,2,7,1,3],val=5
输出: [ 4 , 2 , 7 , 1 , 3 , 5 ] [4,2,7,1,3,5] [4,2,7,1,3,5]
解释: 另一个满足题目要求可以通过的树是:
请添加图片描述

思路:

如下演示视频中可以看出:只要按照二叉搜索树的规则去遍历,遇到空节点就插入节点就可以了。如图:
请添加图片描述
递归三部曲:

  • 确定递归函数参数以及返回值
TreeNode insertIntoBST(TreeNode root, int val)
  • 确定终止条件

终止条件就是找到遍历的节点为null的时候,就是要插入节点的位置了,并把插入的节点返回

if (root == null) {
            TreeNode tem = new TreeNode(val);
            return tem;
        }
  • 确定单层递归的逻辑
if (val < root.val) {
            TreeNode tem = insertIntoBST(root.left, val);
            root.left = tem;
        } else {
            TreeNode tem = insertIntoBST(root.right, val);
            root.right = tem;
        }

总体代码如下: 递归法:

class Solution {
    public TreeNode insertIntoBST(TreeNode root, int val) {
        if (root == null) {
            TreeNode tem = new TreeNode(val);
            return tem;
        }
        if (val < root.val) {
            TreeNode tem = insertIntoBST(root.left, val);
            root.left = tem;
        } else {
            TreeNode tem = insertIntoBST(root.right, val);
            root.right = tem;
        }
        return root;
    }
}


Topic3删除二叉搜索树中的节点

题目:

给定一个二叉搜索树的根节点 r o o t root root 和一个值 k e y key key,删除二叉搜索树中的 k e y key key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。
一般来说,删除节点可分为两个步骤:

  • 首先找到需要删除的节点;
  • 如果找到了,删除它。

示例:
请添加图片描述

输入: r o o t = [ 5 , 3 , 6 , 2 , 4 , n u l l , 7 ] , k e y = 3 root = [5,3,6,2,4,null,7], key = 3 root=[5,3,6,2,4,null,7],key=3
输出: [ 5 , 4 , 6 , 2 , n u l l , n u l l , 7 ] [5,4,6,2,null,null,7] [5,4,6,2,null,null,7]
解释: 给定需要删除的节点值是 3 3 3,所以我们首先找到 3 3 3 这个节点,然后删除它。
一个正确的答案是 [ 5 , 4 , 6 , 2 , n u l l , n u l l , 7 ] [5,4,6,2,null,null,7] [5,4,6,2,null,null,7], 如下图所示:
请添加图片描述

另一个正确答案是 [ 5 , 2 , 6 , n u l l , 4 , n u l l , 7 ] [5,2,6,null,4,null,7] [5,2,6,null,4,null,7]

思路:

递归三部曲:

  • 确定递归函数参数以及返回值
TreeNode deleteNode(TreeNode root, int key)
  • 确定终止条件

遇到空返回,其实这也说明没找到删除的节点,遍历到空节点直接返回了

if (root == null) {// 情况1:遍历没找到
            return null;
        }
  • 确定单层递归的逻辑
    有以下五种情况:
    1.第一种情况:没找到删除的节点,遍历到空节点直接返回了
    2.左右孩子都为空(叶子节点),直接删除节点, 返回NULL为根节点
    3.删除节点的左孩子为空,右孩子不为空,删除节点,右孩子补位,返回右孩子为根节点
    4.删除节点的右孩子为空,左孩子不为空,删除节点,左孩子补位,返回左孩子为根节点
    5.左右孩子节点都不为空,则将删除节点的左子树头结点(左孩子)放到删除节点的右子树的最左面节点的左孩子上,返回删除节点右孩子为新的根节点。

第五种可以根据下图来理解:
请添加图片描述

if (root.val == key) {// 遍历找到
if (root.left == null && root.right == null) {// 情况2:左右节点都为空
	return null;
}
if (root.left != null && root.right == null) {// 情况3:左节点不空,右节点空
    return root.left;
}
if (root.left == null && root.right != null) {// 情况4:左节点空,右节点不空
     return root.right;
}
if (root.left != null && root.right != null) {// 情况5:左节点不空,右节点不空
     TreeNode tem = root.left;
     while (tem.right != null) {
     	tem = tem.right;
     }
        tem.right = root.right;
        return root.left;
}
 

总体代码如下: 递归法:

class Solution {
    public TreeNode deleteNode(TreeNode root, int key) {
        if (root == null) {// 情况1:遍历没找到
            return null;
        }
        if (root.val == key) {// 遍历找到
            if (root.left == null && root.right == null) {// 情况2:左右节点都为空
                return null;
            }
            if (root.left != null && root.right == null) {// 情况3:左节点不空,右节点空
                return root.left;
            }
            if (root.left == null && root.right != null) {// 情况4:左节点空,右节点不空
                return root.right;
            }
            if (root.left != null && root.right != null) {// 情况5:左节点不空,右节点不空
                TreeNode tem = root.left;
                while (tem.right != null) {
                    tem = tem.right;
                }
                tem.right = root.right;
                return root.left;
            }
        }
        if (root.val > key)
            root.left = deleteNode(root.left, key);
        else
            root.right = deleteNode(root.right, key);
        return root;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1513646.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

国内使用GPT4的5种解决方案,最后一个是全场最佳

ChatGPT4是目前世界上最先进的自然语言处理模型 大家都知道ChatGPT4特别好用 我个人来说&#xff0c;基本上每天都会用GPT来查资料、写代码和润色文章 但是在国内&#xff0c;使用ChatGPT4&#xff0c;是有一定门槛的 门槛一 mo法问题 ChatGPT的网站&#xff0c;国内是无法访问…

javaEE13(网站第8章两个课后题)

1、对“jspservletjavabean实现分页查询”功能做如下补充&#xff1a; &#xff08;1&#xff09;记录批量删除&#xff1a;每个记录前添加复选框&#xff0c;点击批量删除&#xff0c;删除选中记录。 增加跳转到任意页功能。用户可改变每页记录条数。 页面&am…

ImportError: Plotly express requires pandas to be installed.

在 Python3 环境下&#xff0c;使用 plotly 绘图时&#xff0c;发生了如下错误&#xff1a; ImportError: Plotly express requires pandas to be installed. 通过排查发现是使用了折行导入时报错的&#xff1a; import plotly.express as px 通过检索找到了解决办法&#xff0…

VScode Error Lens插件

安装完成之后&#xff0c;当我们输入一些错误的语法格式的时候&#xff0c;它都会有一些提示&#xff01; 一开始是英文提示 修改为中文提示 设置搜索 typescript.local

【gpt实践】李某的AI课程值199吗

先说个人的答案&#xff1a;不值。但也不是说毫无价值&#xff0c;只是他的价值没那么高。 文末分享该课程&#xff0c;大家有兴趣可以看看&#xff0c;该课程是否有价值。 “清华博士”推出的199元的AI课程销售额竟然突破了5000万。这一数字让人惊叹&#xff0c;也引发了人们…

免费AI软件开发工具测评:iFlyCode VS CodeFlying

前言 Hello&#xff0c;各位看官&#xff0c;今天为大家带来两款人工智能的软件开发工具的测评&#xff0c;他们分别是iFlyCode和CodeFlying&#xff0c;我相信当大家看到这两款产品名字的时候不禁都会有些好奇&#xff0c;两个产品都有Code 和Fly两个元素&#xff0c;那他们之…

Consul 配置持久化

当我们在consul的key-value中配置了几个字段 访问后的结果: 但是当我们在控制台输入命令重启consul服务后: consul agent -dev 刚刚设置的key-value值便消失不见了 此时就要进行 consul 持久化配置. 第一步:在consul文件夹下创建 1.空文件夹mydata 2.新建文件consul_star…

电脑截图的方式有哪些?

针对使用电脑截图&#xff0c;可以下个截图软件&#xff0c;到目前位置感觉用得不错的是Snipaste这一款&#xff0c;看下图所示。下载链接 Snipaste - 截图 贴图 需要根据自己的电脑配置&#xff0c;选择下载对应的版本。就不详细介绍怎么安装了。 具体操作&#xff1a;在电脑…

在linux上部署yolov5和安装miniconda3

第一步&#xff1a;安装miniconda3 官网&#xff1a;Miniconda — Anaconda documentation 这四个命令快速而安静地安装最新的64位版本的安装程序&#xff0c;然后自行清理。要为Linux安装Miniconda的不同版本或体系结构&#xff0c;请在wget命令中更改.sh安装程序的名称。 …

安卓 OpenGL ES 学习笔记

文章目录 OpenGL 学习笔记OpenGL 是什么&#xff1f;OpenGL ES是什么&#xff1f;怎么用&#xff1f;hello world如何实现动画效果 参考文章 OpenGL 学习笔记 OpenGL 是什么&#xff1f; OpenGL&#xff08;Open Graphics Library&#xff09;是一个跨平台的图形编程接口&…

MySQL8 设置大小写敏感

问题描述 今天对我本地的数据库迁移服务器上&#xff0c;完成之后启动项目报错 说数据库中不存在 quartz_LOCKS 这张表 我打开服务器上面的数据上面展示的表名是 quartz_LOCKS&#xff0c;然后通过查询 lower_case_table_names 配置可知 show variables like lower_case_tabl…

图片格式转换怎么操作?这一个方法快快收藏

图片格式转换能够改变图片的质量、大小兼容性。不同的图片格式用途也不同&#xff0c;当我们需要转换图片格式的时候要怎么操作呢&#xff1f;下面&#xff0c;小编给大家分享一款操作简单&#xff0c;小白也能轻松上手的图片转换器&#xff08;https://www.yasuotu.com/geshi&…

[ThinkPHP]Arr返回1

$detailId (int)Arr::get($detail, null); var_dump($detailId); 打印结果&#xff1a;int(1) 原因&#xff1a; vendor/topthink/think-helper/src/helper/Arr.php

Spring启动“--”设置参数没生效

现象 在idea中启动SpringBoot项目时&#xff0c;使用“--”设置的启动参数没有生效&#xff0c;如修改端口号“--server.port8082” 原因 排查发现是因为在使用SpringApplication.run启动项目时&#xff0c;没有将args参数传入run方法。 修复方案 SpringApplication.run参数中…

【漏洞复现】宏景HCM downlawbase SQL注入漏洞

0x01 产品简介 宏景人力资源管理软件是一款人力资源管理与数字化应用相融合&#xff0c;满足动态化、协同化、流程化、战略化需求的软件。 0x02 漏洞概述 宏景HCM downlawbase 接口处存在SQL注入漏洞&#xff0c;未经过身份认证的远程攻击者可利用此漏洞执行任意SQL指令&…

综合实验---Web环境搭建

题目&#xff1a; 服务器IP地址规划&#xff1a;client&#xff1a;12.0.0.12/24&#xff0c;网关服务器&#xff1a;ens36:12.0.0.1/24、ens33&#xff1a;192.168.10.1/24&#xff0c;Web1&#xff1a;192.168.10.10/24&#xff0c;Web2&#xff1a;192.168.10.20/24&#xf…

53、WEB攻防——通用漏洞CRLF注入URL重定向资源处理拒绝服务

文章目录 CRLF注入原理&检测&利用URL重定向web拒绝服务 CRLF注入原理&检测&利用 URL重定向 就是url中存在urlhttps://xxx&#xff0c;重定向的页面没有限制。主要用来做钓鱼。 web拒绝服务 例如&#xff0c;图片的长宽参数由前端传入&#xff0c;恶意的数据…

vmware虚拟机命令安装Vmware tools

安装Vmware tools sudo apt-get autoremove open-vm-tools sudo apt-get install open-vm-tools-desktop

记OnlyOffice的两个大坑

开发版&#xff0c;容器部署&#xff0c;试用许可已安装。 word&#xff0c;ppt&#xff0c;excel均能正常浏览。 自带的下载菜单按钮能用。 但config里自定义的downloadAs方法却不一而足。 word能正常下载&#xff0c;excel和ppt都不行。 仔细比对调试了代码。发现app.js…

VsCode远程免密登录

创建本地密匙 按下WinR输入cmd&#xff0c;输入 ssh-keygen -t rsa然后连续回车直到结束 找到Your public key has been saved in C:\Users\Administrator/.ssh/id_rsa.pub&#xff0c;每个人都不一样找到密匙所在地 打开id_rsa.pub这个文件&#xff0c;可以用记事本打开&am…