红黑树(RBtree)

有可能是因为输入不够随机,也有可能经过某些插入和删除操作,二叉搜索树有可能会失去平衡而造成效率低下的情况。红黑树是一种平衡的二叉搜索树。

红黑树(RBtree)定义

红黑树不仅仅是一个二叉搜索树,而且满足以下规则:

  1. 每个节点的颜色不是红色就是黑色;
  2. 根节点的颜色为黑色。
  3. NULL节点视为黑色;
  4. 如果每个节点的颜色为红色,则其子节点的颜色必须为黑色;
  5. 任何一个节点到NULL(树尾端)的任何路径,所含的黑色节点数必须相同。

所以,根据规则4,新增节点的颜色必须为红色;根据规则3,新增节点的父节点颜色必须为黑色。

插入节点

左旋转

红黑树(RBtree)_第1张图片

右旋转

情况一:

插入的节点为根节点。
对策:直接将节点的颜色改为黑色。

情况二:

插入节点的父节点为黑色。
对策:插入节点的颜色为红色,此时并没有破坏红黑树的规则。

情况三:

插入节点的父节点和叔叔节点都是红色。
对策:
此时祖父节点一定存在。将当前节点的父节点和叔叔节点涂黑,祖父结点涂红,再将祖父节点变成当前节点,从新的当前节点开始重新运行此插入算法。(图片来源:saturnman)
插入节点4,变化前:
红黑树(RBtree)_第2张图片
变化后:
红黑树(RBtree)_第3张图片

情况四

当前节点的父节点是红色,叔叔节点是黑色,当前节点是其父节点的右子节点。
对策:
把当前节点的父节点做为新的当前节点,以新当前节点为支点做左旋转操作。
插入节点7,变化前:
红黑树(RBtree)_第4张图片
变化后:
红黑树(RBtree)_第5张图片

情况五

当前节点的父节点是红色,叔叔节点是黑色,当前节点是其父节点的左子节点。
对策:父节点变为黑色,祖父节点变为红色,以祖父节点为支点右旋转。
插入节点2,变化前:
红黑树(RBtree)_第6张图片
变化后:
红黑树(RBtree)_第7张图片

你可能感兴趣的:(数据结构,红黑树)