让你彻底了解红黑树

当面试官问你什么是红黑树?红黑树的的特性和优势是什么?,在什么情况下需要变色,什么情况下需要旋转?

小伙伴们不要懵,我来慢慢的揭开红黑树的神秘面纱。

想要理解红黑树,就要理解什么是二叉查找树(Binary Search Tree)?

二叉查找树(BST)的特征——(简称左小右大)

1)左子树上所有的节点的值均小于或等于它的根节点的值。
2)右子树上所有的节点的值均大于或等于它的根节点的值。
3)左右子树也分别为二叉排序树

下图中的这棵树就是一颗经典的二叉查找树
在这里插入图片描述
1)如果想查找10,则先与根节点比较,10>9,所以10会出现在根节点的右子树中,再查看右节点13。

在这里插入图片描述
根据左小右大原则,以此类推
在这里插入图片描述
结论:查找所需的最大次数等同于二叉查找树的高度。

但是在插入数据时二叉查找树有一个缺陷,那就是会出现左右不平衡的现象,
例如:初始的二叉树有三个节点,如下图所示
在这里插入图片描述
此时依次插入以下五个结点:7,6,5,4,3,根据二叉查找树的特性,但是会变成这个样子。
在这里插入图片描述呃呃!!有点太丑了

为了解决这一不平衡问题,红黑树就应运而生了。

红黑树是一种自平衡的二叉查找树。除了符合二叉查找树的基本特性之外,还具备其他的特性,满足以下五个规则:

规则1.结点是红色或黑色。

规则2.根结点是黑色。

规则3.每个叶子结点都是黑色的空结点(NIL结点)。

规则4.每个红色结点的两个子结点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色结点)

规则5.从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。

下面展示的是一个典型的红黑树
在这里插入图片描述
红黑树从根到叶子的最长路径不会超过最短路径的2倍。

当插入或删除结点的时候,红黑树的规则有可能被打破,所以需要做一些调整,这样才能继续维持平衡。

那么,什么情况下会破坏红黑树的规则,什么情况下不会破坏规则呢?我们举两个的例子:

  1. 向原红黑树中插入值为14的新结点:
    在这里插入图片描述
    由于父节点15是黑色结点,因此这种情况并不会破坏红黑树的规则,无需做任何调整。

  2. 当插入节点21时,由于父结点22是红色结点,因此这种情况打破了红黑树的规则4,则需要做调整。
    在这里插入图片描述
    调整的方法有两种:变色和旋转,旋转又包括左旋转和右旋转。

  3. 变色:为了重新符合红黑树的规则,尝试把红色结点变为黑色,或者把黑色结点变为红色。
    2.旋转

    2.1左旋转:

    逆时针旋转红黑树的两个结点,使得父结点被自己的右孩子取代,而自己成为自己的左孩子。
    看下图:
    

    在这里插入图片描述
    图中,身为右孩子的Y取代了X的位置,而X变成了自己的左孩子。此为左旋转。

右旋转:顺时针旋转红黑树的两个结点,使得父结点被自己的左孩子取代,而自己成为自己的右孩子。大家看下图:
在这里插入图片描述
图中,身为左孩子的Y取代了X的位置,而X变成了自己的右孩子。此为右旋转。

在红黑树插入新结点的时候,可以分为5种不同的情况,每一种情况有不同的调整方法,
情况1:新结点(A)位于树根,没有父结点。
这种情况,直接让新结点变色为黑色,规则2得到满足。同时,黑色的根结点使得每条路径上的黑色结点数目都增加了1,所以并没有打破规则5。
在这里插入图片描述
情况2:新结点(B)的父结点是黑色
这种局面,新插入的红色结点B并没有打破红黑树的规则,所以不需要做任何调整
在这里插入图片描述
情况3:新结点(D)的父结点和叔叔结点都是红色。
在这里插入图片描述
这种情况,两个红色结点B和D连续,违反了规则4。因此我们先让结点B变为黑色:
在这里插入图片描述
这样一来,结点B所在路径凭空多了一个黑色结点,打破了规则5。因此我们让结点A变为红色:
在这里插入图片描述
这时候,结点A和C又成为了连续的红色结点,我们再让结点C变为黑色:
在这里插入图片描述
经过上面的调整,这重新符合了红黑树的规则。
情况4:新结点(D)的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的右孩子,父结点(B)是祖父结点的左孩子。
在这里插入图片描述
我们以结点B为轴,做一次左旋转,使得新结点D成为父结点,原来的父结点B成为D的左孩子:
在这里插入图片描述
局面5:新结点(D)的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的左孩子,父结点(B)是祖父结点的左孩子。
在这里插入图片描述
我们以结点A为轴,做一次右旋转,使得结点B成为祖父结点,结点A成为结点B的右孩子:
在这里插入图片描述
接下来,我们让结点B变为黑色,结点A变为红色:
在这里插入图片描述
经过上面的调整,这重新符合了红黑树的规则。

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小曾同学.com

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值