使用红黑树实现节点增减的平衡修复 | 带你学《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面向对象编程文章查看此处

相关文章
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
107 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
2月前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
2天前
|
存储 监控 算法
探秘局域网桌面监控:深入剖析 Java 语言核心算法
在数字化办公时代,局域网桌面监控如同企业的“智慧鹰眼”,确保工作效率与数据安全。本文以Java为载体,揭示哈希表在监控中的关键应用。通过高效的数据结构和算法,哈希表能快速索引设备连接信息,大幅提升监控的时效性和响应速度。代码示例展示了如何用Java实现设备网络连接监控,结合未来技术如AI、大数据,展望更智能的监控体系,助力企业在数字化浪潮中稳健前行。
|
2月前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
59 4
|
2月前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
3月前
|
Java 开发者
在Java的集合世界里,Set以其独特的特性脱颖而出,它通过“哈希魔法”和“红黑树防御”两大绝技
【10月更文挑战第13天】在Java的集合世界里,Set以其独特的特性脱颖而出。它通过“哈希魔法”和“红黑树防御”两大绝技,有效抵御重复元素的侵扰,确保集合的纯洁性和有序性。无论是“人海战术”还是“偷梁换柱”,Set都能从容应对,成为开发者手中不可或缺的利器。
36 6
|
3月前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
71 3
|
3月前
|
移动开发 Java 大数据
深入探索Java语言的核心优势与现代应用实践
【10月更文挑战第10天】深入探索Java语言的核心优势与现代应用实践
117 4
|
3月前
|
分布式计算 Java Hadoop
Hadoop-30 ZooKeeper集群 JavaAPI 客户端 POM Java操作ZK 监听节点 监听数据变化 创建节点 删除节点
Hadoop-30 ZooKeeper集群 JavaAPI 客户端 POM Java操作ZK 监听节点 监听数据变化 创建节点 删除节点
81 1
|
3月前
|
分布式计算 安全 Java
Java语言的特点?
Java语言的特点?