二叉树 - 红黑树

2018-05-03  本文已影响0人  烟小花飞花

0. 定义

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

红黑树的特性:

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


    红黑树示例

1. 添加节点

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

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

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

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

2. 删除节点

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

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

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

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

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

3. 练习

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

4. 参考

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

猜你喜欢

热点阅读