12.14_黑马数据结构与算法笔记Java

2023-12-15 08:28

本文主要是介绍12.14_黑马数据结构与算法笔记Java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

120 二叉搜索树 min max

121 二叉搜索树 put

122 二叉搜索树 前任后任1

123 二叉搜索树 前任后任2

124 二叉搜索树 删除1

125 二叉搜索树 删除2

126 二叉搜索树 删除3

127 二叉搜索树 删除 递归1

128 二叉搜索树 删除 递归2

129 二叉搜索树 范围查询

130 二叉搜索树 e01-e03 删增查

131 二叉搜索树 e04 判断合法 中序非递归

132 二叉搜索树 e04 判断合法 中序递归1

133 二叉搜索树 e04 判断合法 中序递归2

134 二叉搜索树 e04 判断合法 上下界

135 二叉搜索树 e05 求范围和

136 二叉搜索树 e06 根据前序遍历结果建树1

137 二叉搜索树 e06 根据前序遍历结果建树2

138 二叉搜索树 e06 根据前序遍历结果建树3

139 二叉搜索树 e07 最近公共祖先

140 avl树 概述

141 avl树 高度和平衡因子

142 avl 四种失衡情况

143 avl 旋转


120 二叉搜索树 min max

递归代码

非递归代码

121 二叉搜索树 put

122 二叉搜索树 前任后任1

123 二叉搜索树 前任后任2

124 二叉搜索树 删除1

125 二叉搜索树 删除2

126 二叉搜索树 删除3

127 二叉搜索树 删除 递归1

意思是:假如我要删除的是6,那我现在就要将7返回,然后让4指向7,这样就断开了4和6的连接,那就可以删除6了。

因此,通俗来说,就是将要删除的节点的孩子返回,然后让删除节点的父母指向要删除的节点的孩子。 

这一部分的代码是找出要删除的节点。因为如果node.key=key就走到后面的代码去了,就不会在着三个if走。 

这一部分的代码意思是,拿原先给的图片来做例子

来一个伪递归

private BSTNode doDelete(BSTNode node,int key){
//比如我要删除的是6   key=6
if(node == null){
return null;
}
if(key < node.key){ 
node.left = doDelete(node.left,key);
return node;
} 
if(key> node.key){  6>4
node.right =    private BSTNode doDelete(BSTNode node,int key){//现在传进来的是4的右孩子也就是6,而且6没有左孩子,因此,直接走下面这几行代码
if(node.left == null){
return node.right; //这里的意思是返回6的右孩子,也就是7
} /return node;
} 
if(node.left == null){
return node.right;
} 
if(node.right == null){
return node.left;
}
}

下一步

private BSTNode doDelete(BSTNode node,int key){
//比如我要删除的是6   key=6
if(node == null){
return null;
}
if(key < node.key){ 
node.left = doDelete(node.left,key);
return node;
} 
if(key> node.key){  6>4
node.right =    private BSTNode doDelete(BSTNode node,int key){//现在传进来的是4的右孩子也就是6,而且6没有左孩子,因此,直接走下面这几行代码
if(node.left == null){
return 7/return node;
} 
if(node.left == null){
return node.right;
} 
if(node.right == null){
return node.left;
}
}

下一步

private BSTNode doDelete(BSTNode node,int key){
//比如我要删除的是6   key=6
if(node == null){
return null;
}
if(key < node.key){ 
node.left = doDelete(node.left,key);
return node;
} 
if(key> node.key){  6>4
node.right =7/return node;
} 
if(node.left == null){
return node.right;
} 
if(node.right == null){
return node.left;
}
}

 下一步

private BSTNode doDelete(BSTNode node,int key){
//比如我要删除的是6   key=6
if(node == null){
return null;
}
if(key < node.key){ 
node.left = doDelete(node.left,key);
return node;
} 
if(key> node.key){
node.right =7
return node;//返回6 这个删除的节点
} 
if(node.left == null){
return node.right;
} 
if(node.right == null){
return node.left;
}
}

而这个时候。因为node.right =7了,因此,树已经连接好,就是被删除节点的父母已经找到了要删除节点的孩子,也意味着6已经被删除了,因为已经没有人和它牵手了。

这里的作用是:连接被删除节点的孩子们和被删除节点的父母的关系 

 

128 二叉搜索树 删除 递归2

node是指要删除的节点

node 是4,node.right 是5,因此s是5,进入循环,找到node的右孩子的左孩子 

让原来node(被删除节点的左孩子全部托付给s,也就是托付给5) 

 

 

 可是如果要删除的节点和根节点之间有距离,需要再加一些步骤。

那这个时候就有疑问了,那会不会和没有距离的那些情况搞混淆了?不会的,他这里就是加了一步递归,实际上就是做了一次无用功。还是拿刚才的例子做说明。

node 是4       s是5

我这里传进去的都是5,而且5只有右孩子,因此,doDelete这个方法中它直接走下面这行代码 。return的就是6

 

所以,s.right 还是等于6,因此没有改变任何东西,只是做了无用功。 

回归正题,如果就是根节点和被删除节点之间就是隔了很多的元素,那代码解读应该如下 :

先解释一下图片的含义:4是被删节点,5是要后继节点。首先先将5拿开,让6和7进行相连接,然后再删除4,让5替代4的位置。因为如果倒数第二行和倒数第三行的代码调换过来的话,就会导致图片1的5那里有两个孩子,增加麻烦。

好的,我们来解释一下代码:

将4的右节点也就是8和4的后继节点也就是5传入doDelete,也就是将以8为树根的这棵树传进去,删掉5,之前的伪代码演示中可以发现doDelete可以删除5操作。因此就从图一转换为图二

node.left是2,将这个2这个孩子交给s,成为s也就是5的做左孩子。

 

129 二叉搜索树 范围查询

但是,对于greater方法来说,如果用正着来遍历的话,就得把所有都遍历完,但如果采用反向遍历,就不需要。因此,优化代码:

最终完整的代码:

因为最后的最后返回的是被删除节点,因此,要创建一个集合来收集被删除元素,而被删除元素又只有一个,因此,取【0】即可以。

 

130 二叉搜索树 e01-e03 删增查

递归有一些缺点就是,做了一些不必要的操作,比如我要新增1,但是在递归的过程中,又把已经连接好的5和2又连接一次。 

 

131 二叉搜索树 e04 判断合法 中序非递归

Long的最小值小于整数的最小值。 

 

132 二叉搜索树 e04 判断合法 中序递归1

进行优化,以下:

解释一下为什么是在boolean a 下面添加if判断:因为isValidBST (node.left )传进去的是6的left,也就是传进去的3,因此,a的真假是说明3是否符合条件。那既然3不符合的话,直接返回false就好了,就没有必要还去比较6这个值了。 这种行为也叫做剪枝。

 

如果是这样,该怎么遍历呢?直接从8开始。

红色的是来,黑色(深紫色也算黑色,当时搞错颜色了而已)的是回。

一层层走。

133 二叉搜索树 e04 判断合法 中序递归2

局部变量在一个方法中发生了改变,不会影响其他的方法。因此要把它放到全局去看

第一种修改方式:

第二种修改方式:

创建一个对象,而不是一个变量。Long和Integer都不行,它们的值不可以发生改变,一定要AtomicLong,因为它可以改变。

一些小方法:

 

 

134 二叉搜索树 e04 判断合法 上下界

135 二叉搜索树 e05 求范围和

 

第二种方法:伪递归来一次

红色的是来,绿色的是回,紫色的是最后一步

136 二叉搜索树 e06 根据前序遍历结果建树1

137 二叉搜索树 e06 根据前序遍历结果建树2

 

理解:

先拿个8过来,确立好的左限和右限,然后拿5。5小于8,可以做为8的左孩子。然后拿1,1小于5,可以做5的左孩子。然后拿7, 7大于5,因此,1的左右孩子为null,完毕。然后拿10。10超过了5的上限,因此5完毕。。以此类推。。

 

138 二叉搜索树 e06 根据前序遍历结果建树3

 

139 二叉搜索树 e07 最近公共祖先

 

140 avl树 概述

导致失衡的原因:删除,添加。

141 avl树 高度和平衡因子

 

142 avl 四种失衡情况

对于LL和RR只要做一次旋转:

LL:失衡点向右旋转一次

RR:失衡点向左旋转一次 

对于LR和RL要做两次旋转:

LR:先让失衡点的右孩子左旋转,再让失衡点右旋转

RL:先让失衡点的左孩子右旋转,再让失衡点左旋转

143 avl 旋转

要先更新红色节点才能更新黄色节点,要先将下面的高度算好,才可以算上面的高度,这样才会准确。

这篇关于12.14_黑马数据结构与算法笔记Java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/495787

相关文章

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows