美文网首页
二叉树 - 红黑树

二叉树 - 红黑树

作者: 烟小花飞花 | 来源:发表于2018-05-03 14:51 被阅读0次

0. 定义

R-B Tree,全称是Red-Black Tree,又称为“红黑树”,它一种特殊的二叉查找树。红黑树的每个节点上都有存储位表示节点的颜色,可以是红(Red)或黑(Black)。

红黑树的特性:

  1. 每个节点或者是黑色,或者是红色。
  2. 根节点是黑色。
  3. 每个叶子节点(NIL)是黑色。(注意:这里叶子节点,是指为空(NIL或NULL)的叶子节点!)
  4. 如果一个节点是红色的,则它的子节点必须是黑色的。(没有两个连续的红色节点)
  5. 从一个节点到该节点的子孙节点的所有路径上包含相同数目的黑节点。


    红黑树示例

1. 添加节点

注意:新添加的节点均为红色

  1. 如果插入的是根节点,直接涂黑

  2. 如果插入节点的父节点是黑色,不用调整
    此时并未破坏原有的树的特性。

  3. 如果插入节点的父节点是红色
    这时看叔叔节点

  • 如果叔叔节点是红色
    将父节点和叔叔节点变为黑色,祖父节点变为红色,然后将祖父节点看做当前节点继续处理
  • 如果叔叔节点是黑色
    • 如果父节点是祖父节点的左孩子,当前节点是其父节点的左孩子,则做LL旋转,互换父节点和祖父节点的颜色
    • 如果父节点是祖父节点的左孩子,当前节点是其父节点的右孩子,则做LR旋转,第二次旋转时互换祖父节点和新的父节点的颜色
    • 如果父节点是祖父节点的右孩子,与上面两种情况互为镜像

2. 删除节点

删除节点和普通二叉查找树删除节点一样,都是删除其后继节点。

以下当前节点均是指其后继结点

  1. 如果当前节点是红色,直接删除即可

  2. 如果当前节点是黑色,且为根节点,直接删除即可

  3. 如果当前节点是黑色(由红黑树的性质可以推断,黑色节点必定有兄弟节点)

  • 如果兄弟节点是红色(则兄弟节点的孩子为黑色)
    可以对父节点进行左旋,交换父节点和兄弟节点的颜色,使当前节点的兄弟节点变为黑色,继续进行处理
  • 如果兄弟节点是黑色,并且当前节点是父节点的左孩子
    • 如果兄弟节点的两个孩子都是黑色
      交换兄弟节点和父节点的颜色,把父节点当做当前节点,继续处理
    • 如果兄弟节点的右孩子为红色
      交换兄弟节点和父节点的颜色,右孩子变黑,父节点左旋
    • 如果兄弟节点的左孩子为红色
      交换兄弟节点和左子的颜色,兄弟节点右旋,此时变为右子为红色的情况
  • 如果兄弟节点是黑色,并且当前节点是父节点的右孩子
    与上面左孩子情况互为镜像

3. 练习

跟着这篇文章操作一遍,基本能全部掌握:数据结构之红黑树插入与删除全程演示

4. 参考

  1. 《算法导论》
  2. 最容易懂得红黑树
  3. 【数据结构和算法05】 红-黑树(看完包懂~)
  4. 数据结构之红黑树插入与删除全程演示

相关文章

  • 红黑二叉树

    红黑二叉树 红黑二叉树(简称:红黑树),它首先是一棵二叉树,同时也是一棵自平衡的排序二叉树。 红黑树在...

  • 红黑树

    啥是红黑树,红黑树 = 二叉树

  • 红黑树原理

    红黑树原理 学习红黑树之前,你首先要有查询二叉树的知识储备,和平衡二叉树(AVL)的知识储备。 红黑树是基于AVL...

  • 【数据结构】红黑树

    1、什么是红黑树? 红黑树是一个要求不那么严格的平衡二叉树搜索树(平衡二叉搜索树/AVL树=平衡二叉树+二叉搜索树...

  • 数据结构-红黑树

    红黑树 红黑树(Red Black Tree) 是一种自平衡二叉查找树 红黑树是一种特化的AVL树(平衡二叉树[h...

  • 树结构之红黑树

    红黑树是在二叉树的基础上加了红、黑两种颜色。 树: 有序树无序树 二叉树:所有结点的度都小于等于2前序遍历,中序遍...

  • 树与二叉树

    **树 ** 二叉树 满二叉树 完全二叉树 三种遍历方法 树与二叉树的区别 二叉查找树 平衡二叉树 红黑二叉树

  • 不可多得的后端架构师技术图谱!内附参考资料!

    数据结构 二叉树 完全二叉树 平衡二叉树 二叉查找树(BST) 红黑树 B-,B+,B*树 LSM 树 队列 集合...

  • 2017.11.1

    红黑树 BBST:自平衡的二叉树(1)根结点为黑,外部节点为黑。(2)其余节点,若为红,则只能有黑孩子。(3)外部...

  • 2019-05-03 二叉排序树,平衡树,哈夫曼树

    二叉排序树 那么啥是红黑树呢? 平衡二叉树 哈夫曼树 wpl最小的二叉树

网友评论

      本文标题:二叉树 - 红黑树

      本文链接:https://www.haomeiwen.com/subject/kahmlftx.html