java基础概念49-数据结构2

ops/2024/12/13 17:39:04/

一、树

1-1、树的基本概念

1、树的节点

2、二叉树

3、树的高度

1-2、二叉查找树

普通二叉树没有规律,不方便查找,没什么作用

1、基本概念

2、添加节点

此时,该方式添加形成的二叉查找树,根节点就是第一个节点。

3、查找节点

4、二叉树的遍历

  • 前序遍历
  • 中序遍历
  • 后序遍历
  • 层序遍历 
①前序遍历

②中序遍历(最常用

获取到的数据是从小到大的!所以,这种遍历方式是最常见的!

③后序遍历

④层序遍历

5、二叉查找树的弊端 

此时,查询效率太低了!

一棵树想要提高查询效率,要树的左、右高度差不多!——平衡二叉树。

1-3、平衡二叉树

1、平衡二叉树的旋转机制

目的:在构建二叉树的时候,保持平衡。 

①、左旋

【示例1】:

左旋步骤1:(简单)

【示例2】:

左旋步骤2:(复杂)

②、右旋

【示例1】:

右旋步骤1:(简单)

【示例2】:

右旋步骤2:(复杂)

 

 

③、平衡二叉树需要旋转的四种情况
1、左左:一次右旋

 

 

2、左右:先局部左旋,再整体右旋

步骤一:局部左旋

步骤二:整体右旋

3、右右:一次左旋

4、右左:先局部右旋,再整体左旋

步骤一:局部右旋

步骤二:整体左旋

小结:

 1-4、小结-树的演变

1-5、红黑树

 1、红黑规则

2、构建红黑树

添加节点时,默认节点是红色的,因为效率高!(按照红黑规则调整的次数少!)

旋转的时候,先把叶子nil结点去掉,直接转,转完再把nil节点加上即可!

【示例】:

 【步骤一】:添加第一个节点

 【步骤二】:添加第二个节点

非根,父节点是黑色,不做调整。

 【步骤三】:添加第三个节点

 【步骤四】:添加第四个节点

非根,父红,叔叔红色:

 

 【步骤五】:添加第五个节点

非根,父节点是黑色,不做调整。

 

 【步骤六】:添加第六个节点

 

3、红黑树的性能

红黑树的增、删、改、查,性能都比较好!

在构建红黑树的过程中,调整次数多的是改变颜色(只是改变节点里面存储颜色的变量的值),旋转的操作(旋转操作比较耗时!),对比平衡二叉树,少太多了!


http://www.ppmy.cn/ops/141595.html

相关文章

HTTP 常见状态码解析

HTTP 常见状态码解析 文章目录 HTTP 常见状态码解析一、引言二、1XX 信息性状态码(一)100 Continue(二)101 Switching Protocols 三、2XX 成功状态码(一)200 OK(二)201 Created&…

NoSQL大数据存储技术测试(5)MongoDB的原理和使用

单项选择题 第1题 关于 MongoDB 集群部署下面说法不正确的是() 已经不使用主从复制的模式 在实际应用场景中, Mongodb 集群结合复制集和分片机制 MongoDB 支持自动分片, 不支持手动切分 (我的答案) 每…

黑盒白盒测试

任务1 黑盒测试之等价类划分法 【任务需求】 【问题】例:某报表处理系统要求用户输入处理报表的日期,日期限制在2003年1月至2008年12月,即系统只能对该段期间内的报表进行处理,如日期不在此范围内,则显示输入错误信息…

【2】数据分析基础(关于Numpy 的基础 1)

NumPy NumPy是什么?NumPy(Numerical Python的缩写)是一个开源的Python科学计算模块,其中包含了许多实用的数学函数,用来处理数值型数据。 优点: 1. 很多更高级的扩展模块都依赖于NumPy,比如p…

国产物联网平台(IotSharp+IoTGateway+Influxdb)快速上手

环境说明: Visual Studio 2022 CommunityIotSharp代码:https://github.com/IoTSharp/IoTSharp.gitIoTGateway版本:v2.1.1Node版本:v20.18.1Influxdb版本:v2.7.11 安装Node Node.js官网 官网下载并安装,…

Android Studio 控制台输出的中文显示乱码

1. Android Studio 控制台输出的中文显示乱码 1.1. 问题 安卓在调试阶段,需要查看app运行时的输出信息、出错提示信息。乱码,会极大的阻碍开发者前进的信心,不能及时的根据提示信息定位问题,因此我们需要查看没有乱码的打印信息。…

机器学习周报(12.2-12.8)

文章目录 摘要Abstract Vision Transformer1 原理2 代码 摘要 本周学习了Vision Transformer (ViT) 的基本原理及其实现,并完成了基于PyTorch的模型训练、验证和预测任务。深入理解了ViT如何将图像分割成patch作为输入序列,并结合Transformer Encoder处…

Pydantic中的discriminator:优雅地处理联合类型详解

Pydantic中的discriminator:优雅地处理联合类型详解 引言1. 什么是discriminator?2. 基本使用示例3. discriminator的工作原理4. 更复杂的实际应用场景5. 使用建议6. 潜在陷阱和注意事项结论最佳实践 引言 在Python的类型系统中,有时我们需要…