红黑树【自平衡的二叉搜索树】

首先

红黑树虽然本质上是一棵二叉查找树,但它在二叉查找树的基础上增加了着色和相关的性质使得红黑树相对平衡,从而保证了红黑树的查找、插入、删除的时间复杂度最坏为O(log n)。加快检索速率。

AVL 数的平衡是指左右节点的高度的绝对值不能超过1,而红黑树的平衡界定是指左右节点的深度不超过1倍

红黑树的5个性质:

  1. 节点的颜色只能是红色或者黑色;
  2. 根节点是黑色的;(根性质
  3. NIL 节点的颜色是黑色;
  4. 如果节点的颜色是红色,则其子节点均为黑色;(红性质
  5. 从任一节点到其后代任一叶子节点的路径上的黑色节点的数量相同;(黑性质

红黑树的旋转:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SGfO9648-1647261099179)(%E9%9D%A2%E8%AF%95%E9%A2%98%E7%9B%AE.assets/image-20220307170324205.png)]

  • 如果你插入的时候只有一个父结点那么就不要任何操作直接插入即可
    在这里插入图片描述

  • 右右型RR:先左旋再变色

    如何判断是RR型,那么就要看刚插入的结点在爷爷结点的左边还是右边,如果是右边那么就是右右型,左边就是左左型
    在这里插入图片描述

  • 父结点和叔叔结点都是红色的:父叔结点都要变黑祖父变红。祖父变成当前节点,因为根结点不能为红所以就把他变成黑。
    在这里插入图片描述

  • 右左型RL:先右旋将模型转成右右类型RR,将6这个结点变成新输入的结点然后再左旋然后变色。
    在这里插入图片描述
    注意:左左和左右型都是和上面的基本上是一样的知识变换了一下位置而已所以这里就不在赘述了!

最后

最后一点需要说明的时候红黑树是很重要的一个知识点,在大厂的面试中特别喜欢问红黑树相关的知识点,尤其是他是如何自平衡的和AVL树的自平衡有什么区别!!
好了,红黑树的自平衡整理的差不多收工!

彩蛋

如果说看着我这个动图还是不了解的同学,给你们推荐一个网站,可以自己动手去实现!这样更快上手!希望对你的理解有更大的帮助!
https://www.cs.usfca.edu/~galles/visualization/RedBlack.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

聪明不喝牛奶

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

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

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

打赏作者

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

抵扣说明:

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

余额充值