HashMap源码(七) —— 红黑树删除原理分析 动态图解析!!!

红黑书的删除本质上是一个穷举的过程

删除情况说明

  1. 删除的节点没有子节点的情况
    a) 如果为红色,直接删除即可,不会影响黑色节点的数量
    b) 如果为黑色,删除的时候需要进行平衡操作
  2. 删除的节点只有一个子节点时,删除节点只能是黑色,子节点也只能是红色。否则无法满足红黑树黑色节点完全平衡的特性(从任一节点到其每个叶子的所有简单路径都包含相同数目的黑色节点)
  3. 如果删除节点有两个子节点时,使用后继节点作为替换的删除节点,然后再按照前面两种情况处理

删除情况具体分析

1. 删除的节点没有子节点(非null节点)的情况

 a、如果为红色,直接删除即可,不会影响黑色节点的数量
   删除红色节点(13)示例(不影响黑色节点数量,不需要平衡操作)
在这里插入图片描述
 b、如果为黑色,删除的时候需要进行平衡操作
   删除示例,删除节点11(平衡操作后面会介绍到)
在这里插入图片描述

2. 删除的节点只有一个子节点时,删除节点只能是黑色,子节点也只能是红色。

  为什么该情况下,删除节点只能是黑色,子节点只能是红色,如图所示:
      在这里插入图片描述

 由于该情况下删除节点的子节点只有一个,并且是红色,删除后直接将删除节点的子节点的颜色变黑,父节点和子节点连接即可。由于删除的黑色节点被变成黑色的红色子节点顶上,整体不影响黑色节点的数量,还是符合红黑树的特性,所以不需要进行平衡操作。

 删除节点动态示例,删除节点11(分别是含左子树右子树的情况):
含左子树情况含右子树情况

3. 如果删除节点有两个子节点时,使用前驱节点或后继节点作为替换的删除节点,然后再按照前面两种情况处理(本文示例以前驱节点为例)

找到的前驱节点有两种情况,分别是前驱节点无子节点的情况和前驱节点只有左子节点的情况.
同时删除节点和找到的前驱节点的颜色都不固定,所以又区分了好多情况。

下面演示示例只演示其中一种,大概了解一下变化规则。具体的平衡逻辑在后面会介绍到。
比如删除节点100,首先会找到前驱节点60,然后替换内容后,将后继节点删除。即将删除情况转变成上面介绍到的两种情况。删除完成后,再做节点平衡操作(后面会介绍具体平衡细节)。
 删除示例,删除100节点
  在这里插入图片描述

红黑树删除平衡情况分析

前面分析的三种情况,1.a 和 2 这两种情况下删除比较简单,不需要做红黑树节点平衡操作,而 3 这种情况之前也分析了,通过用前驱节点或者后继节点替换被删除的节点,将删除情况转换成1、2这种情况然后再删除,又由于1.a 和 2 不需要进行平衡处理,所以后面删除平衡操作主要围绕1.b的情况分析。

首先为了方便后面的描述,对节点进行一个名称的约束,如下图所示:
在这里插入图片描述
对于删除平衡操作也是一个穷举的过程(删除黑色节点引起的平衡问题)

分析: 删除节点的时候,找到前驱节点,并替换两个节点的内容

  1. 如果找到要删除前驱节点含有子节点的情况时,前驱节点一定是黑色,前驱节点的子节点一定是红色,这种情况就是上述第2种情况,删除前驱节点,将前驱节点变成黑色,不需要进行平衡操作。
  2. 如果找到要删除的前驱节点没有子节点,并且前驱节点是红色时。这种情况就是上述1.a 的情况,替换内容后直接删除即可,由于是红色节点,不影响黑色节点的数量。所以不需要进行平衡操作。
  3. 如果找到要删除的前驱节点没有子节点,并且前驱节点是黑色时,这种情况就是上述1.b的情况。因为删除的的是黑色节点,直接影响到红黑树中黑色节点的数量,需要进行数的平衡。这种情况比较复杂,后面内容就只针对这种情况处理。
以下内容是删除的节点找到的前驱节点是没有子节点的黑色节点的情况(也就是删除删除黑色叶子节点的情况)
  • S 是黑色的情况
    a、 当 P 是 红 色 \color{red}{当P是红色} P
  • 3
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值