红黑树删除操作之简单记忆方法

学习红黑树知识点不清楚的,可以参考这篇博文红黑树原理以及插入、删除算法 附图例说明

因为删除操作比插入操作较难理解,需要处理的情况比较多,便于简单记忆,及快速了解删除操作,特此发博文,三句话说清楚红黑树的删除该如何处理,基本上按照这三句话的操作,自己模拟一下,就会大概清楚红黑树如何删除节点的了。

三句话对应三种删除处理动作(三种情况可交叉组合处理):

删除节点的值与前驱或后继节点的值交换(原位置颜色不变)

  • 再进行AVL调整,再颜色变化(AVL调整后,把删除节点设为红色,再往上调整颜色)
  • 删除节点所在位置为红色,则直接删除
  • 不需要AVL调整,则设置与删除节点的值所在层为红色,再向上调整颜色

转载于:https://my.oschina.net/u/4163811/blog/3074329

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
红黑树删除操作相对于插入操作要复杂一些,因为删除节点后需要保证红黑树的性质仍然成立。下面是红黑树删除操作步骤: 1. 找到要删除的节点,如果该节点有两个子节点,则找到该节点的后继节点(即右子树中最小的节点)来替代该节点。 2. 如果要删除的节点是红色节点或者被替代的后继节点是红色节点,则直接删除该节点,并用后继节点替代该节点。 3. 如果要删除的节点是黑色节点,则需要进行复杂的调整操作,以保证红黑树的性质仍然成立。具体步骤如下: 1)如果要删除的节点是叶子节点,则直接删除该节点,并将其父节点的相应子节点指针置为NULL。 2)如果要删除的节点只有一个子节点,则用该子节点替代该节点,并将该子节点的颜色改为黑色。 3)如果要删除的节点有两个子节点,则找到该节点的后继节点来替代该节点,并将后继节点的颜色赋值给要删除的节点。然后删除后继节点。 4)如果要删除的节点是黑色节点,并且其子节点都是黑色节点,则需要进行调整操作。具体步骤如下: a. 将要删除的节点替换为NULL,并记录该节点的父节点和兄弟节点。 b. 如果该节点是根节点,则直接结束删除操作。 c. 如果该节点的兄弟节点是红色节点,则需要进行旋转操作,将兄弟节点变为黑色节点。具体步骤如下: i. 如果兄弟节点是父节点的左子节点,则进行右旋操作。 ii. 如果兄弟节点是父节点的右子节点,则进行左旋操作。 iii. 将兄弟节点的颜色改为父节点的颜色,并将父节点的颜色改为黑色。 iv. 如果兄弟节点有子节点,则将其子节点的颜色改为红色。 v. 将要删除的节点的父节点指向NULL,删除操作结束。 d. 如果该节点的兄弟节点是黑色节点,并且其子节点都是黑色节点,则需要将兄弟节点变为红色节点,并将父节点作为新的要删除的节点进行递归操作。 e. 如果该节点的兄弟节点是黑色节点,并且其左子节点是红色节点,则需要进行旋转操作,将兄弟节点的左子节点变为新的兄弟节点。具体步骤如下: i. 如果兄弟节点是父节点的左子节点,则进行左旋操作。 ii. 如果兄弟节点是父节点的右子节点,则进行右旋操作。 iii. 将新的兄弟节点的颜色改为黑色,并将其左子节点的颜色改为红色。 iv. 将要删除的节点的父节点指向NULL,删除操作结束。 f. 如果该节点的兄弟节点是黑色节点,并且其右子节点是红色节点,则需要进行旋转操作,将兄弟节点变为父节点的颜色,并将其右子节点变为黑色节点。具体步骤如下: i. 如果兄弟节点是父节点的左子节点,则进行右旋操作。 ii. 如果兄弟节点是父节点的右子节点,则进行左旋操作。 iii. 将兄弟节点的颜色改为父节点的颜色,并将父节点的颜色改为黑色。 iv. 将新的兄弟节点的右子节点的颜色改为黑色。 v. 将要删除的节点的父节点指向NULL,删除操作结束。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值