数据结构中的树 --- 红黑树

红黑树是一种几近平衡的二叉搜索树, 但不是AVL树.

1 红黑树的一些特殊性质

1. 每个节点皆为红色或者黑色。

2. 根节点是黑色。

3. 每个叶子节点(NIL)是黑色(注意, 每个叶子节点必须都为空节点, 也就是指针为nullptr, 无key值)。

4. 每个红色结点的两个子结点一定都是黑色。

5. 任意一结点到以其为根节点的树的每个叶子结点的路径都包含数量相同的黑结点。

2 红黑树的插入和删除操作

2.1 插入操作

当我们要插入一个key值的节点时, 需要走以下步骤

1. 按照二叉搜索树的插入操作规则插入节点(此时节点并无颜色, 但是我们要通过后续操作让此时的树变为红黑树).

2. 把新插入的节点(如果不是根节点的话)置为红色

原因如下:

根据性质5, 如果将新插入的节点A置为黑色, 那么A需要有两个黑色的子节点(空的), 那么其父节点到A的两个叶子节点的路径上就会有两个黑色节点(包括A和A的子节点), 多出A到其他叶节点的1个.

3. 如果当前节点的父节点是红色, 进行"调整"(具体调整方法如下).

调整:

由于此时插入节点为红色且其父节点也为红色, 那么此时树不满足红黑树的性质4, 那么就不是一棵红黑树, 那么需要让其满足性质4. 如图:

3.1 叔叔节点也是红色

将父节点和叔叔节点均置为黑色, 若祖父节点不是根节点, 将祖父节点置为红色, 将当前节点置为祖父节点, 对当前节点继续进行"调整"

如例题所示, 当我们要插入key值为35的节点:

  • 发现需要插在50的左子节点, 然后置为红色:

  • 发现35的父亲50和叔叔节点75都为红色, 那么把二者都置为黑色, 并把祖父节点60置为红色:

  • 当前节点为60, 红色, 其父节点40和叔叔节点120皆为红色, 那么将二者置为黑色, 祖父节点为根节点, 不变色:

3.2 叔叔节点为黑色, 且当前节点是右孩子

当前节点是红色, 父节点也是红色, 但是其叔叔节点是黑色, 且当前节点是父节点的右孩子, 那么就将父节点左旋.

3.3 叔叔节点为黑色, 且当前节点是左孩子

当前节点是红色, 父节点也是红色, 但是其叔叔节点是黑色, 且当前节点是父节点的左孩子, 那么就将父节点置为黑色, 将祖父节点置为红色, 并将祖父节点右旋.

2.2 删除操作

删除操作, 跟二叉搜索树的操作一样, 先把节点删除, 然后:

1. 如果节点是叶节点, 那么直接删除

2. 如果被删除的节点只有一个子节点, 那么子节点直接代替删除节点位置

3. 如果被删除节点有左右子节点, 那么找出中序遍历的后继节点, 把要删除的节点的值更新为其后继节点的值, 然后删除后继节点(注意, 其后继节点必然是其右子树的中序遍历的第一个节点, 也就是肯定不会有左子节点, 但凡有左子节点, 左子节点一定排在它本身前面, 所以被删除的节点最多有一个子节点, 可以按照1, 2情况对其进行分析).

4. 如果删除的节点位置是黑色节点, 那么就需要进行"调整"

调整:

调整还是根据删除后的当前情况进行.

删除节点后, 当前树可能会不符合红黑树的2,4,5性质, 也就是根节点为黑色, 红色节点的子节点为黑色, 节点到该节点的子孙节点的所有路径上包含相同数目的黑节点. 此时我们需要观察删除的那个节点位置代替者的情况, 如果其原本为红色, 直接将该位置置为黑色, 结束调整. 如果其原本为黑色且是该位置为根节点, 也是不需要做什么, 结束掉

那么剩下的情况就是, 被删除的节点为黑色, 且代替他位置的节点也为黑色, 且该位置不是根节点, 那么有以下四种情况(假设当前节点为删除位置的节点):

https://www.jianshu.com/p/e136ec79235c

1. 兄弟节点为红色

2. 兄弟节点为黑色, 且兄弟节点的子节点也都为黑色

3. 兄弟节点为黑色, 且兄弟节点左子为红色, 右子为黑色

4. 兄弟节点为黑色, 且兄弟节点右子为红色.

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

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

相关文章

c++数据结构中 顺序队列的队首队尾_数据结构与算法—队列详解

前言栈和队列是一对好兄弟,前面我们介绍过数据结构与算法—栈详解,那么栈的机制相对简单,后入先出,就像进入一个狭小的山洞,山洞只有一个出口,只能后进先出(在外面的先出去)。而队列就好比是一个隧道&#…

phpstudy apache无法启动_phpstudy和wamp哪个好

刚刚接触php的同学会想知道phpstudy和wamp的区别有哪些?phpstudy和wamp哪个好?下面我们来总结一下。一:phpstudy好还是wamp好php的运行环境配置对于新手都是一件比较困难的事情,但是对于高手配置是一件繁琐的事情,个人…

哈夫曼树(最优二叉树)

1 用途 现在假如有一个需求, 把一个很长的字符串用二进制编码的形式存储, 要尽可能的占用较小空间, 那么应该怎么存储呢. 肯定是要确定每个字母的编码方法, 比如 001是A, 010是B等. 那么要怎么确定每个字符编成什么二进制码从而使得总长度最短? 一个根本思想是, 出现频率高的…

visual studio无法更新_VS Code Python 扩展 5 月更新

(给Python编程开发加星标,提升编程技能.)12 号,微软在官方博客发布了 VS Code 编辑器中 Python 扩展的 5 月更新,其中只有一个较为重要的特性:新增了浏览选择 Python 解释器的能力。增加这个功能,主要是为了让选择或变…

至强cpu型号列表_装机必看——CPU型号参数详解

装机必看——CPU型号参数详解——装机个人练习生-海在初步解了电脑构成后,我们DIY装机首先要看的就是如何选CPU,今天就带大家详细学习CPU的各类数据。说到CPU,我们先来介绍下生产CPU的两大公司——Intel和AMD。这两家公司相爱相杀接近50年了&…

多路平衡查找树 --- B(B-)树

1 简介 可以用阶数来描述B树, 一棵M阶B树代表着该B树最多有M个孩子节点. 如果M为2, 那么该B树就是一棵二叉搜索树. 一棵M阶B树具有以下性质: 1. 每个节点最多有M - 1个关键字. 跟普通的树不同, B树的关键字有多个. 2. 根节点最少可以只有一个关键字. 3. 非根节点至少有k个关…

B+树操作方式

1 简介 B树与B树相似, 也存在不同. 可以理解为把所有元素都放在叶子节点, 索引B树化的树. B树的一些性质: 1. B树的节点分类: 内部节点(索引节点), 叶子节点. 如果只有根节点有元素, 那么其可以是内部节点也可以是叶子节点. 2. B树与B树最大的不同是内部节点不保存数据, 只…

java执行查询postgresql得到中文乱码_比这个夏天还要热的PostgreSQL数据库来啦!

什么是PostgreSQL?云数据库 PostgreSQL 是京东云基于开源的 PostgreSQL 10.6 版本构建的一款功能强大的企业级关系型数据库管理系统。PostgreSQL有“世界上可获得的最先进的开源数据库”之称,在过去20年的飞速发展中,该数据库已经广泛应用在G…

python按列读取txt文件_如何使用pandas读取txt文件中指定的列(有无标题)

最近在倒腾一个txt文件,因为文件太大,所以给切割成了好几个小的文件,只有第一个文件有标题,从第二个开始就没有标题了。 我的需求是取出指定的列的数据,踩了些坑给研究出来了。 import pandas as pd # 我们的需求是 取…

jpa多表关联查询_Spring Boot 整合mybatis如何自定义 mapper 实现多表关联查询

上一篇文章已经介绍了自定义 mapper 实现自定义的方法,其实实现了通过自定义的mapper就可以做多表关联等复杂查询。但是很多朋友还是反馈说没有实现多表关联查询,所以,今天把文章又重新修改了,增加了多表关联的实现步骤。Mybatis …

spark on yarn 完全分布式_「大数据」(七十一)Spark之架构介绍

【导读:数据是二十一世纪的石油,蕴含巨大价值,这是情报通大数据技术系列第[71]篇文章,欢迎阅读和收藏】1 基本概念Spark 架构采用了分布式计算中的 Master-Slave 模型。 Master 是对应集群中的含有 Master 进程的节点,…

计算机网络数据链路层 --- 停止等待协议

停止等待协议的意义 除了比特出差错,底层信道还会出现丢包问题。为了实现流量控制。 停止等待协议的前提 虽然现在常用全双工通信方式,但为了讨论问题方便,仅考虑一方发送数据(发送方),一方接收数据&…

python import如何使用_python之import引用

关于python的import引用的最大关键是init.py文件的作用,这个文件对于import的方法使用至关重要。这个是我在搭建自动化框架过程中用到的import的方法使用。 比如说,我现在login.py想引用bottom底下的log.py的时候,这个时候,我们如…

计算机网络数据链路层 --- 后退n帧协议(GBN)

滑动窗口 发送窗口 发送方维持一组连续的允许发送的帧的序号 接收窗口 接收方维持一组连续的允许接收帧的序号 发送过程 如图,假如发送方的发送窗口大小是6,首先发送0号帧,并建立0号帧的副本,防止帧丢失,然后发送…

简要描述内部连接和外部连接之间的区别_创新性的M12推拉式连接器推拉标准—跨制造商自动化技术的里程碑...

“八家知名制造商 – 菲尼克斯,浩亭,莫仕,穆尔电子,宾德,康耐,艾查和魏德米勒因建立M12推拉式连接器的推拉锁紧机制而在市场上确立了地位。我们共同追求一个目标,即确保各个制造商之间的兼容性。…

计算机网络数据链路层 --- 选择重传协议(SR)

引言 GBN协议的弊端 累计确认,从而导致某一帧错误后会批量重传。 可行的解决方案 可以只重传出错的帧,设置单个确认,同时加大接收窗口,设置接收缓存,缓存乱序到达的帧。这也就是选择重传协议SR。 SR中的滑动窗口 …

requests 返回的cookies为空_爬虫学习(2)(requests库)

POST请求import requestsdata {name: cxc, age: 18} r requests.post("http://httpbin.org/post", datadata) print(r.text)POST请求这样就成功地获得了返回结果,form部分就是提交的数据,证明POST请求成功发送了。响应之前我们使用了text和c…

计算机网络 --- 数据链路层介质访问控制

引言 传输数据使用的两种链路: 点对点链路:两个相邻的节点通过一个链路相连,没有第三者。应用:PPP协议,常用于广域网。广播式链路:所有主机共享通信介质。应用:早期的总线以太网,无…

6-7 使用函数输出水仙花数_学习C语言居然对printf函数不理解???

对于C语言的printf函数,可以说是我们学习C语言第一个接触到的函数了。printf命令的作用是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。printf()函数的调用格式为:printf("", )。printf()是C语言标准库函数&#xff…

matplotlib 子图超过4个_Matplotlib从入门到精通

Matplotlib从入门到精通​mp.weixin.qq.comMatplotlib是基于Python语言的开源项目,旨在为Python提供一个数据绘图包。它提供了一整套和 matlab 相似的命令 API,十分适合交互式地进行制图。而且也可以方便地将它作为绘图控件,嵌入 GUI 应用程序…