红黑树的旋转与变色

缘起

在此之前,笔者写过一篇关于TreeMap工作原理的简单解析,其中限于当时知识和时间有限,暂没有解析关于树的旋转和变色等操作。后来笔者查询了一部分资料也参考了很多文章,终于弄清楚变色和旋转是如何工作的。本文主要详解一下红黑树的变色和旋转是如何工作的。

为什么红黑树要旋转和变色

这需要从红黑树的特效说起,红黑树发明之初就定义了以下5个特性,因为这几个特性,使得红黑树成为一个相对平衡的二叉树,也就能提高红黑树的工作效率。
红黑树是一种自平衡的二叉查找树,它在二叉查找树的基础上又具备如下特征:

  1. 节点是红色或黑色。
  2. 根节点是黑色。
  3. 每个叶子节点都是黑色的空节点(NIL节点)。
  4. 每个红色节点的两个子节点都是黑色。(从每个叶子到根的所有路径上不能有两个连续的红色节点)
  5. 从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点。

如下图,就是一颗典型的红黑树:
在这里插入图片描述
为了满足如上的规则,实现结构的平衡,我们在插入或删除节点的时候,就需要做一些相应的调整。

例如:
向原红黑树插入值为21的新节点:

  • 18
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值