力扣450 删除二叉搜索树中的节点 Java版本

文章目录

  • 题目描述
  • 思路
  • 代码


题目描述

给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。

一般来说,删除节点可分为两个步骤:

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

示例 1:
在这里插入图片描述

输入:root = [5,3,6,2,4,null,7], key = 3
输出:[5,4,6,2,null,null,7]
解释:给定需要删除的节点值是 3,所以我们首先找到 3 这个节点,然后删除它。
一个正确的答案是 [5,4,6,2,null,null,7], 如下图所示。
另一个正确答案是 [5,2,6,null,4,null,7]。
在这里插入图片描述

示例 2:

输入: root = [5,3,6,2,4,null,7], key = 0
输出: [5,3,6,2,4,null,7]
解释: 二叉树不包含值为 0 的节点
示例 3:

输入: root = [], key = 0
输出: []

提示:

节点数的范围 [0, 104].
-105 <= Node.val <= 105
节点值唯一
root 是合法的二叉搜索树
-105 <= key <= 105

进阶: 要求算法时间复杂度为 O(h),h 为树的高度。

思路

在代码中详细注释了

代码

class Solution {//使用递归的方法public TreeNode deleteNode(TreeNode root, int key) {//本方法采用的是:删除root的时候让左子树充当root,也就是示例一中的第二种答案//递归出口if (root==null){return null;}//如果找到了key,需要删除root这个节点,需要左右子树调整,所以选择采用后序遍历的方式,能够利用左右子树返回的结果TreeNode leftChild = deleteNode(root.left,key);//得到左子树的根节点TreeNode rightChild = deleteNode(root.right,key);//得到右子树的根节点//调整root的左右子树root.left = leftChild;root.right =rightChild;if (root.val==key){//找到key//如果这个节点是叶子节点就直接删除就行了,也就是直接返回nullif (leftChild==null&&rightChild==null){return null;}//左子树为空就返回右子树if (leftChild==null){return rightChild;}//右子树为空就返回左子树if (rightChild==null){return leftChild;}else {//如果右子树不为空就对子树的结构做出调整TreeNode cur = rightChild;//找到右子树中最左下方的节点,因为需要让这个节点的左孩子指向leftChild的右孩子//可以拿[5,3,6,2,4,null,7] key=5 这个案例在纸上画一下,删除5之后,4需要挂在6的左孩子的地方才符合二叉搜索树while (cur.left!=null){cur = cur.left;}cur.left = leftChild.right;}//删除根节点,左子树成为根节点leftChild.right = rightChild;return leftChild;}return root;}
}

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

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

相关文章

【CKA模拟题】如何发布一个SVC资源

题干 For this question, please set this context (In exam, diff cluster name) kubectl config use-context kubernetes-adminkubernetesYou have an existing Nginx pod named nginx-pod . Perform the following steps: Expose the nginx-pod internally within the cl…

Gorm连接Mysql数据库及其语法

Gorm连接Mysql数据库及其语法 文章目录 Gorm连接Mysql数据库及其语法前期工作找到Gorm的github项目简单了解相关MySQL语法 启动数据库定义数据库模型注意点Gorm Model定义结构体标签(tag)支持的结构体标记&#xff08;Struct tags&#xff09;关联相关标记&#xff08;tags&…

重庆交通大学2024年蓝桥杯测试赛3题解(AK Java版)

A. 拼成长方体 题目描述: 有n个边长为1的立方体积木(这种立方体称为单位立方体),问可以拼成几种长方体。一个长方体,竖起来、平着放、侧着放,视为同一个长方体。 输入描述: 输入数据占一行,为一个正整数n,n≤1000。 输出描述: 输出每个长方体的长、宽、高,格式…

openGauss学习笔记-251 openGauss性能调优-使用Plan Hint进行调优-行数的Hint

文章目录 openGauss学习笔记-251 openGauss性能调优-使用Plan Hint进行调优-行数的Hint251.1 功能描述251.2 语法格式251.3 参数说明251.4 建议251.5 示例 openGauss学习笔记-251 openGauss性能调优-使用Plan Hint进行调优-行数的Hint 251.1 功能描述 指明中间结果集的大小&a…

Redis持久化策略和优缺点

首先来谈谈什么是持久化&#xff1f; 持久化就是将数据从内存保存到磁盘的过程&#xff0c;其目的就是为了防止数据丢失。 为什么要这样做&#xff1f;因为内存中的数据在重启服务器后就会丢失&#xff0c;而磁盘上的数据则不会&#xff0c;因此为了系统稳定&#xff0c;我们…

蓝桥杯刷题记录之黄金树

思路 需要注意的就是它的节点编号是从1开始的&#xff0c;Node的l和r是int类型&#xff0c;而不是Node类型&#xff0c;因为题目在给定l和r的时候&#xff0c;给的是下标而不是一个node对象&#xff0c;其余的就没有了&#xff0c;树的遍历这个贼简单 代码 import java.util…

学习AIGC大模型的步骤

学习大模型及相关技术&#xff0c;您可以按照以下步骤进行&#xff1a; 基础知识储备&#xff1a; •理解机器学习的基本概念&#xff0c;包括监督学习、无监督学习、强化学习等。 •掌握深度学习的基础理论&#xff0c;包括神经网络的工作原理、反向传播、激活函数等。 •学习…

产品经理面试自我介绍,这3大错误千万别犯!

金三银四求职季&#xff0c;你是不是也有面试的冲动&#xff01;但面试并不是头脑一热就能取得好结果&#xff0c;在此之前&#xff0c;必须得有周全的准备&#xff0c;才能应对好面试官的“连环问”&#xff01; 所以&#xff0c;今天这篇产品经理面试干货分享给大家~ 今天文…

最大的开源大模型:马斯克的Grok-1可供企业商用

由马斯克xAI团队研发的最大的开源大语言模型Grok-1&#xff0c;从头开始训练的总参数量为314B&#xff08;3140亿&#xff09;的混合专家&#xff08;MoE&#xff09;模型&#xff0c;其规模超过ChatGPT-3.5&#xff0c;目前Grok背后代码和权重架构已全部开放上线在GitHub。 下…

[简单粗暴]一文彻底搞懂Java泛型中的PECS原则(在坑里躺了多年终于爬出来了)

[简单粗暴]一文彻底搞懂Java泛型中的PECS原则(在坑里躺了多年终于爬出来了) 两种限定通配符 表示类型的上界&#xff0c;格式为&#xff1a;<&#xff1f; extends T>&#xff0c;即类型必须为T类型或者T子类表示类型的下界&#xff0c;格式为&#xff1a;<&#xf…

SqlServer服务启动报错10013

错误提示&#xff1a;MSSQLSERVER 服务启动异常不错10013 Windows不能在本地计算机启动SQLServer(MSSQLSERVER)。有关更多信 息&#xff0c;查阅系统事件日志。如果这是非Microsoft服务&#xff0c;请与服务厂商联系&#xff0c;并 参考特定服务错误代码10013。 解决 1、先禁用…

蓝桥杯 2023 省A 颜色平衡树

树上启发式合并是一个巧妙的方法。 dsu on tree&#xff0c;可以称为树上启发式合并&#xff0c;是一种巧妙的暴力。用一个全局数组存储结果&#xff0c;对于每棵子树&#xff0c;有以下操作&#xff1a; 先遍历轻儿子&#xff0c;处理完轻儿子后将数组清零&#xff08;要再…

网络七层模型之数据链路层:理解网络通信的架构(二)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

Day14-集合(二)--什么是数据结构

什么是数据结构 计算机存储和组织数据的方式 数据结构概述 数据结构是计算机底层存储、组织数据的方式 是指数据相互之间是以什么方式排列在一起的 数据结构是为了更加方便管理和使用数据&#xff0c;需要结合具体的业务场景来进行选择 精心选择的数据结构可以带来更高的运…

Linux相关命令(1)

1、找出文件夹下包含 “aaa” 同时不包含 “bbb”的文件&#xff0c;然后把他们重新生成一下。要求只能用一行命令。 find ./ -type f -name "*aaa*" ! -name "*bbb*" -exec touch {} \;文件系统操作命令 df&#xff1a;列出文件系统的整体磁盘使用情况 …

2024/3/23 蓝桥杯

P1102 A-B 数对 二分 import java.util.Arrays; import java.util.Scanner;public class Main {public static void main(String[] args) {//A-BCScanner sc new Scanner(System.in);int n sc.nextInt();int C sc.nextInt();int[] res new int[n1];for(int i1;i<n;i) {…

普通用户无法连接到docker服务

环境 tt:~$ lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 22.04.3 LTS Release: 22.04 Codename: jammy问题 tt:~$ sudo apt install docker.io -ytt:~$ docker info Client:Version: 24.0.5Context: d…

小孔平板应力集中问题matlab有限元编程【源码+PPT讲义】|三节点三角形单元|平面单元|稀疏矩阵 |Comsol网格

专栏导读 作者简介&#xff1a;工学博士&#xff0c;高级工程师&#xff0c;专注于工业软件算法研究本文已收录于专栏&#xff1a;《有限元编程从入门到精通》本专栏旨在提供 1.以案例的形式讲解各类有限元问题的程序实现&#xff0c;并提供所有案例完整源码&#xff1b;2.单元…

样本投递技术

投递技术 APT 组织主要以邮件作为投递载体&#xff0c;邮件的标题、正文和附件都可能携带恶意代码。主要的方式是附件是漏洞文档、附件是二进制可执行程序和正文中包含指向恶意网站的超链接这三种。 APT攻击的载荷类型&#xff1a; 文档类&#xff1a;主要是office文档、pdf文…

NEFU 《JAVA语言程序设计》实验三 类的继承、接口和多态

1. (程序题)设计具有工作能力接口Workable&#xff0c;声明抽象方法updateName()&#xff0c;通过传入的字符串修改姓名&#xff1b;声明抽象方法calculateSalary()&#xff0c;返回计算的薪资 设计员工实体类Employee&#xff0c;公司下所有员工均包含&#xff0c;姓名&#x…