java8 TreeMap红黑树节点删除源码解析

本文详细解析了Java8中TreeMap基于红黑树的节点删除操作,包括红黑树的基本规则、删除节点的整体分析、具体情形分析及源码解读。删除节点时考虑了四种可能情况,并通过旋转和颜色调整保持红黑树性质。
摘要由CSDN通过智能技术生成

目录

一、红黑树的规则

二、红黑树节点删除整体分析

三、红黑树节点删除具体情形分析

四、TreeMap删除节点源码解析


      红黑树添加节点的平衡操作相对简单,具体分析参考java8 TreeMap接口实现源码解析,红黑树节点删除需要考虑的情形和翻转动作更复杂。综合各博客大神对该问题的分析,以TreeMap中红黑树节点删除相关代码为例,记录下自己对该问题的分析和理解,欢迎指正。

一、红黑树的规则

1、每个节点都只能是红色或者黑色

2、根节点是黑色

3、每个叶节点(NIL节点,空节点)是黑色的。

4、如果一个结点是红的,则它两个子节点都是黑的。也就是说在一条路径上不能出现相邻的两个红色结点。

5、从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点,即相同的黑色高度。

重点说明下,所谓的叶节点就是空节点,必须是黑色的,叶节点的父节点可能是红色的,也可能是黑色的。

二、红黑树节点删除整体分析

先不考虑节点颜色问题,被删除的节点可能存在以下四种可能:

1、左右子树为空

2、左子树存在,右子树为空

3、左子树为空,右子树存在

4、左右子树都非空

遇到第四种情形时,处理技巧是先找到比目标节点D大的最小节点即D节点右子树中最左边的一个节点,或者比D小的最大的节点即D节点左子树中最右边的一个节点,记为X节点,将X节点的值复制到D节点上,然后删除X节点。这样处理D节点的左右子树可保持不变,而X节点因为要么是最左边要么是最右边的一个节点,所以X节点的左右子树肯定都为空,即情形四转换成了情形一,旋转操作相对简单。即实际处理时只需要考虑前面三种情形即可,下面一一分析。

三、红黑树节点删除具体情形分析

1、只有左子树或者右子树存在,即情形二和情形三

     因为从父节点到所有的叶子节点的黑色高度必须一致,所以此种情形下,被删除节点D的左子树或者右子树只能是一个红色节点,而D节点只能是黑色的,如下图所示,因为如果D节点为红色的,则D节点的左子树或者右子树必须是黑色的,就违背了黑色高度一致原则,如果D节点是黑色的,DR节点也是黑色的,同样违背了黑色高度一致原则。

      这种情形的处理最简单,删除D节点,用D节点的DR节点代替D节点,并把DR节点涂黑即可。

2、左右子树都为空,即情形一

1)、被删除节点D是红色的

因为删除红色节点不改变该节点所在路径的黑色高度,所以可以直接删除。

2)、被删除节点是黑色的

删除黑色节点肯定会改变该节点所在路径的黑色高度,肯定需要通过左旋或者右旋调整,因为被删除节点D左右子树都为空,所以只能往上考虑D节点的父节点P和兄弟节点S了。同红黑树节点插入的平衡操作,D节点是左节点和D节点是右节点时的旋转方向是相反的,过程是一样的,这里以D节点是左节点为例分析。

     2a)兄弟节点S是红色的

 兄弟节点S是红色的,S的左节点SL和右节点SR一定是黑色的,

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值