漫画:什么是红黑树?

2017 年 11 月 5 日 互联网架构师


相关阅读:

支付宝系统架构参考(架构图,最新揭秘)

2017的金秋,派卧底去阿里、京东、美团、滴滴带回来的面试题及答案

互联网技术(java框架、分布式、集群)干货视频大全,不看后悔!(免费下载)

来源:公号程序员小灰







————————————




















————————————









二叉查找树(BST)具备什么特性呢?


1.子树上所有结点的值均小于或等于它的根结点的值。

2.子树上所有结点的值均大于或等于它的根结点的值。

3.左、右子树也分别为二叉排序树。


下图中这棵树,就是一颗典型的二叉查找树:







1.查看根节点9




2.由于10 > 9,因此查看右孩子13




3.由于10 < 13,因此查看左孩子11




4.由于10 < 11,因此查看左孩子10,发现10正是要查找的节点:
















假设初始的二叉查找树只有三个节点,根节点值为9,左孩子值为8,右孩子值为12:




接下来我们依次插入如下五个节点:7,6,5,4,3。依照二叉查找树的特性,结果会变成什么样呢?





















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


1.向原红黑树插入值为14的新节点:




由于父节点15是黑色节点,因此这种情况并不会破坏红黑树的规则,无需做任何调整。



2.向原红黑树插入值为21的新节点:




由于父节点22是红色节点,因此这种情况打破了红黑树的规则4(每个红色节点的两个子节点都是黑色),必须进行调整,使之重新符合红黑树的规则。







变色:


为了重新符合红黑树的规则,尝试把红色节点变为黑色,或者把黑色节点变为红色。


下图所表示的是红黑树的一部分,需要注意节点25并非根节点。因为节点21和节点22连续出现了红色,不符合规则4,所以把节点22从红色变成黑色:




但这样并不算完,因为凭空多出的黑色节点打破了规则5,所以发生连锁反应,需要继续把节点25从黑色变成红色:




此时仍然没有结束,因为节点25和节点27又形成了两个连续的红色节点,需要继续把节点27从红色变成黑色:




左旋转:


逆时针旋转红黑树的两个节点,使得父节点被自己的右孩子取代,而自己成为自己的左孩子。说起来很怪异,大家看下图:



图中,身为右孩子的Y取代了X的位置,而X变成了自己的左孩子。此为左旋转。



右旋转:


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



图中,身为左孩子的Y取代了X的位置,而X变成了自己的右孩子。此为右旋转。







我们以刚才插入节点21的情况为例:




首先,我们需要做的是变色,把节点25及其下方的节点变色:











由于根节点必须是黑色节点,所以需要变色,变色结果如下:




这样就结束了吗?并没有。因为其中两条路径(17 -> 8 -> 6 -> NIL)的黑色节点个数是4,其他路径的黑色节点个数是3,不符合规则5。


这时候我们需要把节点13看做X,节点8看做Y,像刚才的示意图那样进行右旋转








最后根据规则来进行变色





如此一来,我们的红黑树变得重新符合规则。这一个例子的调整过程比较复杂,经历了如下步骤:


变色 -> 左旋转 -> 变色 -> 右旋转 -> 变色














—————END—————

看完本文有收获?请转发分享给更多人


欢迎关注“互联网架构师”,我们分享最有价值的互联网技术干货文章,助力您成为有思想的全栈架构师,我们只聊互联网、只聊架构,不聊其他!打造最有价值的架构师圈子和社区。

本公众号覆盖中国主要首席架构师、高级架构师、CTO、技术总监、技术负责人等人 群。分享最有价值的架构思想和内容。打造中国互联网圈最有价值的架构师圈子。

  • 长按下方的二维码可以快速关注我们

  • 如想加群讨论学习,请点击右下角的“加群学习”菜单入群




登录查看更多
0

相关内容

【2020新书】实战R语言4,323页pdf
专知会员服务
100+阅读 · 2020年7月1日
【2020新书】使用高级C# 提升你的编程技能,412页pdf
专知会员服务
57+阅读 · 2020年6月26日
【CVPR2020-旷视】DPGN:分布传播图网络的小样本学习
专知会员服务
26+阅读 · 2020年4月1日
【新书】Python数据科学食谱(Python Data Science Cookbook)
专知会员服务
114+阅读 · 2020年1月1日
【新书】Python中的经典计算机科学问题,224页PDF
专知会员服务
52+阅读 · 2019年12月31日
【强化学习】深度强化学习初学者指南
专知会员服务
179+阅读 · 2019年12月14日
可视化理解四元数,愿你不再掉头发
计算机视觉life
31+阅读 · 2019年1月2日
什么是深度学习的卷积?
论智
18+阅读 · 2018年8月14日
通俗理解卷积神经网络(小学生都能看懂)
七月在线实验室
9+阅读 · 2018年1月25日
漫画: 什么是人工智能?
大数据技术
4+阅读 · 2018年1月19日
干货|EM算法原理总结
全球人工智能
17+阅读 · 2018年1月10日
如何简单形象又有趣地讲解神经网络是什么?
算法与数据结构
5+阅读 · 2018年1月5日
Python除了不会生孩子,什么都会
算法与数学之美
3+阅读 · 2017年11月8日
AI都干过什么让人细思极恐的事?
全球创新论坛
4+阅读 · 2017年9月15日
漫画:什么是Bitmap算法?
程序猿
3+阅读 · 2017年8月19日
什么是常识?
keso怎么看
4+阅读 · 2017年8月2日
Arxiv
9+阅读 · 2020年2月15日
Hierarchical Deep Multiagent Reinforcement Learning
Arxiv
8+阅读 · 2018年9月25日
Arxiv
22+阅读 · 2018年2月14日
Arxiv
9+阅读 · 2018年1月30日
Arxiv
7+阅读 · 2018年1月21日
VIP会员
相关VIP内容
【2020新书】实战R语言4,323页pdf
专知会员服务
100+阅读 · 2020年7月1日
【2020新书】使用高级C# 提升你的编程技能,412页pdf
专知会员服务
57+阅读 · 2020年6月26日
【CVPR2020-旷视】DPGN:分布传播图网络的小样本学习
专知会员服务
26+阅读 · 2020年4月1日
【新书】Python数据科学食谱(Python Data Science Cookbook)
专知会员服务
114+阅读 · 2020年1月1日
【新书】Python中的经典计算机科学问题,224页PDF
专知会员服务
52+阅读 · 2019年12月31日
【强化学习】深度强化学习初学者指南
专知会员服务
179+阅读 · 2019年12月14日
相关资讯
可视化理解四元数,愿你不再掉头发
计算机视觉life
31+阅读 · 2019年1月2日
什么是深度学习的卷积?
论智
18+阅读 · 2018年8月14日
通俗理解卷积神经网络(小学生都能看懂)
七月在线实验室
9+阅读 · 2018年1月25日
漫画: 什么是人工智能?
大数据技术
4+阅读 · 2018年1月19日
干货|EM算法原理总结
全球人工智能
17+阅读 · 2018年1月10日
如何简单形象又有趣地讲解神经网络是什么?
算法与数据结构
5+阅读 · 2018年1月5日
Python除了不会生孩子,什么都会
算法与数学之美
3+阅读 · 2017年11月8日
AI都干过什么让人细思极恐的事?
全球创新论坛
4+阅读 · 2017年9月15日
漫画:什么是Bitmap算法?
程序猿
3+阅读 · 2017年8月19日
什么是常识?
keso怎么看
4+阅读 · 2017年8月2日
Top
微信扫码咨询专知VIP会员