使用红黑树实现节点增减的平衡修复 | 带你学《Java语言高级特性》之四十二

简介: 了解了红黑树的基本内容后,本节将结合详细的示例图为读者介绍红黑树对节点增加和节点删除操作的平衡功能的实现原理。

上一篇:认识红黑树,解决二叉树删除后遗症 | 带你学《Java语言高级特性》之四十一
了解了红黑树的基本内容后,本节将结合详细的示例图为读者介绍红黑树对节点增加和节点删除操作的平衡功能的实现原理。

【本节目标】
通过阅读本节内容,你将对树节点的插入和删除操作有更深的理解,并对红黑树的平衡原理有一个直观地分析,进一步掌握树的结构。

数据插入平衡修复

1、新增节点颜色初始默认为红色;
2、第一次插入,由于原树为空,所以只会违反红黑树的规则2,所以只要把根节点涂黑即可;
在进行红黑树处理的时候为了方便操作都会将新的节点使用红色来进行描述,于是当设置根节点的时候就会违反“规则2”,这时只需要将节点的颜色涂黑即可。

3、如果插入节点的父节点是黑色的,那不会违背红黑树的规则,什么也不需要做;但是遇到如下三种情况时,就要开始变色和旋转了:
|- 插入节点的父节点和其叔叔节点(祖父节点的另一个子节点)均为红色的;

image.png

|- 插入节点的父节点是红色,叔叔节点时黑色,且插入节点是其父节点的左子节点;

image.png

|-插入节点的父节点是红色,叔叔节点时黑色,且插入节点是其父节点的右子节点。

image.png

案例分析:

image.png
image.png
image.png

在红黑树进行修复处理之中,它需要根据当前节点以及当前节点的父节点和叔叔节点之间的颜色来推断树是否需要进行修复。

数据删除平衡修复

1、删除操作后,如果当前节点是黑色的根节点,那么不用任何操作,因为并没有破坏书的平衡性,即没有违背红-黑树的规则;
2、如果当前节点为红色的,说明刚刚移走的后继节点是黑色的,那么不管后继节点的父节点是什么颜色,只要将当前节点涂黑就可以了,红-黑树的平衡性就可以恢复;
3、但是如果遇到以下四种情况,就需要通过变色或旋转来恢复红-黑树的平衡了:’
|- 当前节点是黑色的,且兄弟节点是红色的(父节点和兄弟节点的子节点肯定为黑色的);

image.png

|- 当前节点是黑色的,且兄弟节点是黑色的,且兄弟节点的两个子节点均为黑色的;

image.png

|- 当前节点是黑色的,且兄弟节点是黑色的,且兄弟节点的左子节点是红色的,右子节点是黑色的;

image.png

|- 当前节点是黑色的,且兄弟节点是黑色的,且兄弟节点的右子节点是红色的,左子节点是任意颜色;

image.png

案例分析:

image.png
image.png
image.png
image.png

在红黑树之中修复的目的是为了保证树结构中的黑色节点数量平衡,黑色节点数量平衡了,才可能达到“O(logn)”的执行性能,但是修复的过程一方面是红黑的处理,另一方面就是黑色子节点的保存层次。

想学习更多的Java的课程吗?从小白到大神,从入门到精通,更多精彩不容错过!免费为您提供更多的学习资源。
本内容视频来源于阿里云大学

下一篇:使用案例回顾类库相关知识(上) | 带你学《Java语言高级特性》之四十三
更多Java面向对象编程文章查看此处

相关文章
|
6月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
252 4
|
6月前
|
Java
Java语言实现字母大小写转换的方法
Java提供了多种灵活的方法来处理字符串中的字母大小写转换。根据具体需求,可以选择适合的方法来实现。在大多数情况下,使用 String类或 Character类的方法已经足够。但是,在需要更复杂的逻辑或处理非常规字符集时,可以通过字符流或手动遍历字符串来实现更精细的控制。
421 18
|
7月前
|
存储 Java Apache
Java语言操作INI配置文件策略
以上步骤展示了基本策略,在实际项目中可能需要根据具体需求进行调整优化。例如,在多线程环境中操作同一份配置时需要考虑线程安全问题;大型项目可能还需考虑性能问题等等。
297 15
|
8月前
|
算法 Java
Java语言实现链表反转的方法
这种反转方法不需要使用额外的存储空间,因此空间复杂度为,它只需要遍历一次链表,所以时间复杂度为,其中为链表的长度。这使得这种反转链表的方法既高效又实用。
610 0
|
8月前
|
JSON Java API
【干货满满】分享拼多多API接口到手价,用Java语言实现
本方案基于 Java 实现调用拼多多开放平台商品详情 API,通过联盟接口获取商品到手价(含拼团折扣与优惠券),包含签名生成、HTTP 请求及响应解析逻辑,适用于电商比价、导购系统集成。
|
8月前
|
JSON Java API
【干货满满】分享京东API接口到手价,用Java语言实现
本示例使用 Java 调用京东开放平台商品价格及优惠信息 API,通过商品详情和促销接口获取到手价(含优惠券、满减等),包含签名生成、HTTP 请求及响应解析逻辑,适用于比价工具、电商系统集成等场景。
|
8月前
|
JSON Java API
【干货满满】分享淘宝API接口到手价,用Java语言实现
本文介绍了如何使用 Java 调用淘宝开放平台 API 获取商品到手价,涵盖依赖配置、签名生成、HTTP 请求与响应解析等核心实现步骤。
|
9月前
|
JavaScript Java Go
Go、Node.js、Python、PHP、Java五种语言的直播推流RTMP协议技术实施方案和思路-优雅草卓伊凡
Go、Node.js、Python、PHP、Java五种语言的直播推流RTMP协议技术实施方案和思路-优雅草卓伊凡
690 0
|
9月前
|
JSON JavaScript 前端开发
Python+JAVA+PHP语言,苏宁商品详情API
调用苏宁商品详情API,可通过HTTP/HTTPS发送请求并解析响应数据,支持多种编程语言,如JavaScript、Java、PHP、C#、Ruby等。核心步骤包括构造请求URL、发送GET/POST请求及解析JSON/XML响应。不同语言示例展示了如何获取商品名称与价格等信息,实际使用时请参考苏宁开放平台最新文档以确保兼容性。
|
9月前
|
监控 Java API
Java语言按文件创建日期排序及获取最新文件的技术
这段代码实现了文件创建时间的读取、文件列表的获取与排序以及获取最新文件的需求。它具备良好的效率和可读性,对于绝大多数处理文件属性相关的需求来说足够健壮。在实际应用中,根据具体情况,可能还需要进一步处理如访问权限不足、文件系统不支持某些属性等边界情况。
407 14