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

相关文章
|
28天前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
63 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
20天前
|
存储 安全 Java
Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
【10月更文挑战第17天】Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
47 2
|
3天前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
14 4
|
10天前
|
分布式计算 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 若是设置参数该如何设置
|
18天前
|
存储 Java API
优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。
【10月更文挑战第19天】本文介绍了如何优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。内容包括Map的初始化、使用Stream API处理Map、利用merge方法、使用ComputeIfAbsent和ComputeIfPresent,以及Map的默认方法。这些技巧不仅提高了代码的可读性和维护性,还提升了开发效率。
39 3
|
18天前
|
存储 安全 Java
Java Map新玩法:深入探讨HashMap和TreeMap的高级特性
【10月更文挑战第19天】Java Map新玩法:深入探讨HashMap和TreeMap的高级特性,包括初始容量与加载因子的优化、高效的遍历方法、线程安全性处理以及TreeMap的自然排序、自定义排序、范围查询等功能,助你提升代码性能与灵活性。
23 2
|
24天前
|
Java 开发者
在Java的集合世界里,Set以其独特的特性脱颖而出,它通过“哈希魔法”和“红黑树防御”两大绝技
【10月更文挑战第13天】在Java的集合世界里,Set以其独特的特性脱颖而出。它通过“哈希魔法”和“红黑树防御”两大绝技,有效抵御重复元素的侵扰,确保集合的纯洁性和有序性。无论是“人海战术”还是“偷梁换柱”,Set都能从容应对,成为开发者手中不可或缺的利器。
30 6
|
24天前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
41 3
|
27天前
|
移动开发 Java 大数据
深入探索Java语言的核心优势与现代应用实践
【10月更文挑战第10天】深入探索Java语言的核心优势与现代应用实践
42 4
|
1月前
|
消息中间件 分布式计算 Java
大数据-73 Kafka 高级特性 稳定性-事务 相关配置 事务操作Java 幂等性 仅一次发送
大数据-73 Kafka 高级特性 稳定性-事务 相关配置 事务操作Java 幂等性 仅一次发送
27 2
下一篇
无影云桌面