想提高开发效率的必看!传智播客mysql的软件(代码片段)

程序员DCS阿里 程序员DCS阿里     2022-12-10     517

关键词:

二、面试题

面:考你几个红黑树的知识点🦀

  1. 红黑树的数据结构都用在哪些场景,有什么好处?
  2. 红黑树的时间复杂度是多少?
  3. 红黑树中插入新的节点时怎么保持平衡?

面:2-3树都是不没看,回去等消息吧!

三、2-3树与红黑树的等价性

红黑树规则

1. 根节点是黑色
2. 节点是红黑或者黑色
3. 所有子叶节点都是黑色(叶子是NIL节点,默认没有画出来)
4. 每个红色节点必须有两个黑色子节点(也同样说明一条链路上不能有链路的红色节点)
5. 黑高,从任一节点到齐每个叶子节点,经过的路径都包含相同数目的黑色节点

那么,这些规则是怎么总结定义出来的呢?接下里我们一步步分析讲解。

1. 为什么既有2-3树要有红黑树

首先2-3树(读法:二三树)就是一个节点有1个或者2个元素,而实际上2-3树转红黑树是由概念模型2-3-4树转换而来的。-4叉就是一个节点里有3个元素,这在2-3树中会被调整,但是在概念模型中是会被保留的。

虽然2-3-4树也是具备2-3树同样的平衡树的特性,但是如果直接把这样的模型用代码实现就会很麻烦,且效率不高,这里的复杂点包括;

  1. 2-叉、3-叉、4-叉,三种结构的节点类型,互相转换复杂度较高
  2. 3-叉、4-叉,节点在数据比较上需要进行多次,不像2-叉节点,直接布尔类型比较即可非左即右
  3. 代码实现上对每种差异,都需要有额外的代码,规则不够标准化

所以,希望找到一种平衡关系,既保持2-3树平衡和O(logn)的特性,又能在代码实现上更加方便,那么就诞生了红黑树。

2. 简单2-3树转红黑树

2-3树转红黑树,也可以说红黑树是2-3树2-3-4树的另外一种表现形式,也就是更利于编码实现的形式。

简单转换示例;

从上图可以看出,2-3-4树与红黑树的转换关系,包括;

  1. 2-叉节点,转换比较简单,只是把原有节点转换为黑色节点
  2. 3-叉节点,包括了2个元素,先用红色线把两个节点相连,之后拆分出来,最后调整高度黑色节点在上
  3. 4-叉节点,包括了3个元素,分别用红黑线连接,之后拆分出来拉升高度。这个拉升过程和2-3树调整一致,只是添加了颜色

综上,就是2-3-4树的节点转换,总结出来的规则,如下;

  1. 将2-3-4树,用二叉树的形式表示
  2. 3-叉、4-叉节点,使用红色、黑色连线进行连接
  3. 另外,3-叉节点有两种情况,导致转换成二叉树,就有左倾和右倾

3. 复杂2-3树转红黑树

简单2-3树转换红黑树的过程中,了解到一个基本的转换规则右旋定义,接下来我们在一个稍微复杂一点的2-3树与红黑树的对应关系,如下图;

上图是一个稍微复杂点的2-3树,转换为红黑树的过程,是不这样一张图让你对红黑树更有感觉了,同时它也满足一下条件;

  1. 从任意节点到叶子节点,所经过的黑色节点数目相同
  2. 黑色节点保持着整体的平衡性,也就是让整个红黑树接近于O(logn)时间复杂度
  3. 其他红黑树的特点也都满足,可以对照红黑树的特性进行比对

四、红黑树

1. 平衡操作

通过在上一章节2-3树的学习,在插入节点时并不会插到空位置,而是与现有节点融合以及调整,保持整个树的平衡。

而红黑树是2-3-4树的一种概念模型转换而来,在插入节点时通过红色链接相连,也就是插入红色节点。插入完成后进行调整,以保持树接近平衡。

那么,为了让红黑树达到平衡状态,主要包括染色、↔左右旋转、这些做法其实都是从2-3树演化过来的。接下来我们就分别讲解几种规则的演化过程,以此更好了解红黑树的平衡操作。

1.1 左旋转

左旋定义: 把一个向右倾斜的红节点链接(2-3树,3-叉双元素节点),转化为左链接。

背景:顺序插入元素,1、2、3,2-3树保持平衡,红黑树暂时处于右倾斜。

接下来我们分别对比两种树结构的平衡操作;

  1. 2-3树,所有插入的节点都会保持在一个节点上,之后通过调整节点位置,保持平衡。
  2. 红黑树,则需要通过节点的左侧旋转,将元素2拉起来,元素1和元素3,分别成为左右子节点。

红黑树的左旋,只会处理与之对应的2-3树节点进行操作,不会整体改变。

1.2 右旋转

右旋定义: 把一个向左倾斜的红节点连接(2-3树,3-叉双元素节点),转换为右连接。

背景:顺序插入元素,3、1、1,2-3树保持平衡,红黑树暂时处于左倾斜。

接下来我们分别对比两种树结构的平衡操作;

  1. 2-3树,所有插入的节点都会保持在一个节点上,之后通过调整节点位置,保持平衡。
  2. 红黑树,则需要通过节点的右侧旋转,将元素2拉起来,元素1和元素3,分别成为左右子节点。

你会发现,左旋与右旋是相互对应的,但在2-3树中是保持不变的

1.3 左右旋综合运用

左旋、右旋,我们已经有了一个基本的概念,那么接下来我们再看一个可以综合左右旋以及对应2-3树的演化案例,如下;

以上的例子分别演示了一个元素插入的三种情况,如下;

  1. 1、3,插入0,左侧底部插入,与2-3树相比,需要右旋保持平衡
  2. 1、3,插入2,中间位置插入,首先进行左旋调整元素位置,之后进行右旋进行树平衡
  3. 1、3,插入5,右侧位置插入,此时正好保持树平衡,不需要调整

1.4 染色

在2-3树中,插入一个节点,为了保持树平衡是不插入到空位置上的,当插入节点后元素数量有3个后则需要调整中间元素向上,来保持树平衡。与之对应的红黑树则需要调整颜色,来保证红黑树的平衡规则,具体参考如下;

2. 旋转+染色运用案例

接下来我们把上面讲解到的旋转染色,运用到一个实际案例中,如下图;

  • 首先从左侧开始,是一个按照顺序插入生产出来的红黑树,插入顺序;7、2、8、1、4、3、5
  • α,向目前红黑树插入元素6,插入后右下角有三个红色节点;3、5、6
  • β,因为右下角满足染色条件,变换后;黑色节点(3、5)、红色节点(4、6)。
  • γ,之后看被红色连线链接的节点7、4、2,最小节点在中间,左旋平衡树结构。
  • δ,左旋完成后,红色链接线的7、4、2为做倾顺序节点,因此需要做右旋操作。
  • ε,左旋、右旋,调整完成后,又满足了染色操作。到此恢复红黑树平衡。

注意,所有连接红色节点的,都是是红色线。以此与2-3树做对应。

3. 删除操作

根据2-3-4树模型的红黑树,在删除的时候基本是按照2-3方式进行删除,只不过在这个过程中需要染色和旋转操作,以保持树平衡。删除过程主要可以分为如图四种情况,如下;

3.1 删除子叶红色节点

红色子叶节点的删除并不会破坏树平衡,也不影响树高,所以直接删除即可,如下;

3.2 删除左侧节点

3.2.1 被删节点兄弟为黑色&含右子节点

3.2.2 被删节点兄弟为黑色&含左子节点

3.2.3 被删节点兄弟为黑色&含双子节点(红)

3.2.4 被删节点兄弟为黑色&不含子节点

3.2.5 被删节点兄弟为黑色&含双黑节点(黑)

3.3. 删除右侧节点

3.3.1 被删节点兄弟为黑色&含左子节点

3.3.2 被删节点兄弟为黑色&含右子节点

3.3.3 被删节点兄弟为黑色&含双子节点(红)

3.2.4 被删节点兄弟为黑色&不含子节点

3.2.5 被删节点兄弟为黑色&含双黑节点(黑)

最后

各位读者,由于本篇幅度过长,为了避免影响阅读体验,下面我就大概概括了整理了,需要的话请**点赞后点击这里免费下载文章资料!**

篇幅度过长,为了避免影响阅读体验,下面我就大概概括了整理了,需要的话请**点赞后点击这里免费下载文章资料!**

[外链图片转存中…(img-RdtTAL4I-1626941514172)]

[外链图片转存中…(img-ejL83gSf-1626941514172)]

[外链图片转存中…(img-q0x8HzHL-1626941514173)]

来传智播客的目的

...强大实力。让我知道我还有一次机会,一次让充实自己,提高自己的价值的机会。 &n 查看详情

为什来到传智播客?

...  小白的我以前从来就不知什么叫PHP???什么叫传智播客???来到传智播客,要从我的一同学说起。我的同学是学编程专业。他对编程培训机构有稍微了解。对传智播客这种填压式学习还是很认可,在半年内可以学到... 查看详情

来传智播客的目的以及未来的人生规划

...是很难立足的,为了可以找到满意的工作,所以联系到了传智播客,希望通过传智播客可以学习并掌握一门软件技术,从而成功找到自己想要的工作。 对于未来的人生规划,先从传智播客的php基础班开始学习,从零基础开始... 查看详情

为什么来传智播客

在那么多的培训的结构中传智播客是唯一一个我同学读过的培训结构,经过同学的大概介绍我觉得传智播客是一个可以实现我理想工作的。并且我也是没有找到一个我可以相信的结构,在同学的帮助下我报读了传智播客。来到传... 查看详情

为什么要来传智播客

  为什么要来传智播客学习?这个问题在我脑海里其实想了很多遍,也犹豫了很多次,工作好好的为什么要来这里学习?这个问题一直不停的在我脑子里打转,我很想知道答案。  今天正式第一天来到教室听课学习,... 查看详情

2017最新传智播客黑马java32期全套培训资料

HTML&CSSJavaScriptJQuery基础与实战BootStrap响应式页面开发mysql&jdbc回顾mysql多表&jdbcjdbc连接池&dbutilxmlHttp&TomcatJavaWeb核心技术JDBC加强AJAX&JqueryListenerFilter基础加强LinuxredisJavaWeb综合项目实战hibernates 查看详情

2016北京传智播客第php基础班+就业班(第42期)

...程学习,强力推荐零基础的PHP学员学习,也可以推荐入门提高的同学学习,后面涉及redis等等高级的技术,作为提交也是不错的选择。基础班主要内容:HTML+CSS、JavaScript基础、PHP入门、Apache入门、Mysql入门就业班主要内容:中级... 查看详情

为选择传智播客

...决定选择参加培训班。了解了一下,身边有几个朋友都在传智播客培训过或者正在陪训中 查看详情

传智播客_怎么样

我目前的工作很累,老板不理解,隔行如隔山啊,自己累死累活干了一天,被老板完全否定,经常加班,5点半下班,8点才走,星期六日老板还想压榨,自己本来技术菜,而且自己改的代码... 查看详情

我和传智播客有个约会

...生。今天我只想谈谈一件决定,那就是我为什么选择了来传智播客学习。 在我的价值观里,一个人的价值体现在他对社会能创造多少价值,为人类社会发展做出多少贡献。我认为有了这样的价值观,虽然改变不了现在的生活... 查看详情

我和传智播客有个约会

...生。今天我只想谈谈一件决定,那就是我为什么选择了来传智播客学习。 在我的价值观里,一个人的价值体现在他对社会能创造多少价值,为人类社会发展做出多少贡献。我认为有了这样的价值观,虽然改变不了现在的生活... 查看详情

为什么我要来传智播客!

...程语言,能够让我满足社会对于人才的需求,从网上看到传智很适合零基础的人,在传智里面可以学习从基础到最新的技术,在网上观看了传智播客的教学视频后,怀着一颗求学求知的心,我决定到传智播客学习PHP,希望在这里... 查看详情

为什么要来传智播客!

        刚到传智播客上课第一天,老师就给同学们提了一个问题,为什么你们要来传智播客呢?经过思考之后,我发现答案其实很简单,就是来学习更多有用的东西的啊!      ... 查看详情

为什么来传智播客?

为什么来传智播客?   首先,传智播客是我在众多IT培训机构的择优结果,真的是不远千里来求学,其实我想说为什么不在成都开php班呢,那边有很多同学需要学习的。   其次,随着“互联网+”时代的到来... 查看详情

揭秘传智播客班级毕业薪资超7k的内幕系列之三----国企慕名而来,将未毕业学员“抢走”,传智播客又一次定义“被就业”

...就业的风向标。但事实上张同学的就业属于“被就业”,传智播客在这个故事里赋予其新的含义。要理解“被就业”在这里的含义。我们须要先了解张同学的就业故事。    5月中旬某天,传智播客咨 查看详情

传智播客javaweb程序设计任务教程黑马程序员课后答案合集

【传智播客】Javaweb程序设计任务教程黑马程序员第一章课后答案【传智播客】Javaweb程序设计任务教程黑马程序员第二章课后答案【传智播客】Javaweb程序设计任务教程黑马程序员第三章课后答案【传智播客】Javaweb程序设计任务... 查看详情

2018年最新传智播客游戏就业班

该视频收集于网络目前是全网最新的传智播客游戏就业班推荐给大家,试看地址链接:https://pan.baidu.com/s/1eTommsE密码:yige内附购买链接,视频收集不易,收取少量费用  查看详情

成都传智播客java培训中心

...xff01;”“IT世界里,人才是最宝贵的财富!”成都传智播客java培训中心,自成立以来!以其雄厚的师资、真实的项目推动,帮助广大的学子走上成才之路!我们有资深的教育团队,一流的名师指导;... 查看详情