面试题:什么是红黑树【不看后悔一生】
1、引入红黑树
今天在学习集合list、set和map的时候,发现set的一个实现类TreeSet和map的一个实现类TreeMap的底层数据结构都是红黑树,于是我仔细查阅了资料了解了什么是红黑树?
2、什么是红黑树?
官方解释:红黑树(Red Black Tree)是一种特殊的自平衡二叉树,简称RBT,即是一种特殊的平衡二叉树(AVL),都是在进行插入和删除操作时通过特定操作保持二叉查找树的平衡,从而获得较高的查找性能。 它可以在O(log n)时间内做查找,插入和删除,这里的n 是树中元素的数目。
说点人能听懂的:就是一种为了提高插入和删除操作的一种算法,最坏的时间复杂度:O(logn)
3、红黑树的五大性质
(1)结点是红色或者黑色。
(2)根结点是黑色。
(3)所有的叶子结点都是黑色。(叶子是NIL结点)
(4)每个红色结点的两个子节点都是黑色。(即不可能出现两个相邻的红色结点)
(5)从任一结点到每个叶子的所有路劲都包含相同数目的黑色结点。
4、话不多说,上图
从上面我们可以了解到,红黑树首先是满足平衡二叉树。那么我们先来看看二叉树(BST)具备什么特性呢?
(1)左子树上所有的结点的值均小于或等于它的根节点的值。
(2)右子树上所有的结点的值均大于或等于它的根结点的值。
(3)左、右子树也分别为二叉排序树。
下面这棵树,就是一颗典型的二叉排序树:
这样的数据结构有什么好处呢?我们来试着查找一下值为10的结点。
1、查看根结点9:
2、根据二叉查找树左子树小、右子树大的特性,10 > 9,因此值为10的结点只可能在根结点的右子树当中,我们查看右孩子结点13:
3、由于10 < 13,因此查看左孩子11:
4、由于10 < 11,因此查看左孩子10,发现10正是要查找的结点:
这样我们就找到了我们想要查找的值,这样的方法就像二分查找法一样, 这样的树看起来查找很方便,但是插入一个值的时候可能就没有你想象的那么友好了,我们来看看。
假设初始的二叉查找树只有三个结点,根结点值为9,左孩子值为8,右孩子值为12:
接下来我们依次插入如下五个结点:7,6,5。见证奇迹的时刻到了:
是不是看起来非常丑,像瘸了一条腿一样,是不是看起来就不平衡了,虽然这样的状态也符合二叉查找树的特性,但是查找的效率远远不如之前,几乎变成了线性查找,那我们应该怎样在插入的时候保证二叉树的平衡呢,那么红黑树就诞生了。
那么问题来了:什么情况下会破坏红黑树的规则,什么情况下不会破坏规则呢?我们举两个简单的例子:
1.向原红黑树插入值为14的新结点:
因为父节点为15黑色结点,插入后并不会破坏红黑树规则,所以不需要做任何调整。
2.向原红黑树插入值为21的新结点:
由于父结点22是红色结点,因此这种情况打破了红黑树的规则4(每个红色结点的两个子结点都是黑色),必须进行调整,使之重新符合红黑树的规则。
那么我们应该怎样调整才能满足红黑树的规则呢?
调整的方法有两种:变色和旋转,旋转又分为左旋转(逆时针)和右旋转(顺时针)。
那用图怎么表示呢?我们一起来看看。
变色:
为了重新符合红黑树的规则,尝试把红色结点变为黑色,或者把黑色结点变为红色。
下图所表示的是红黑树的一部分(子树),新插入的结点Y是红色结点,它的父亲结点X也是红色的,不符合规则4,因此我们可以把结点X从红色变成黑色:
但是,仅仅把一个结点变色,会导致相关路径凭空多出一个黑色结点,这样就打破了规则5,因此,我们需要对其他结点做进一步的调整。
左旋转:
逆时针旋转红黑树的两个结点,使得父节点被自己的右孩子取代,而自己成为自己的左孩子。
图中,身为右孩子的Y取代了X的位置,而X变成了自己的左孩子。此为左旋转。
右旋转:
顺时针旋转红黑树的两个结点,使得父结点被自己的左孩子取代,而自己成为自己的右孩子。大家看下图:
图中,身为左孩子的Y取代了X的位置,而X变成了自己的右孩子。此为右旋转。
5、引入题解
给定下面这颗红黑树,新插入的结点是21:
显然,新结点21和它的父结点22是连续的红色结点,违背了规则4,我们应该如何调整呢?
我们经过三次变色,22变为黑色,25变为红色,27变为黑色:
经过上面的调整,以结点25为根的子树符合了红黑树规则,但结点25和结点17成为了连续的红色结点,违背规则4。
于是,我们把结点25看做一个新结点,正好符合局面5的镜像:
“新结点的父结点是红色,叔叔结点是黑色或者没有叔叔,且新结点是父结点的右孩子,父结点是祖父结点的右孩子”
于是我们以根结点13为轴进行左旋转,使得结点17成为了新的根结点:
接下来,让结点17变为黑色,结点13变为红色:
如此一来,我们的红黑树变得重新符合规则。
6、总结
红黑色的大体思想就是上面描述的那样,里面还有很多情况要考虑,本文只是简单的讲述思想,大家有兴趣可以去百度上看各种情况的考虑。谢谢大家的支持!
面试题:什么是红黑树【不看后悔一生】相关推荐
- 快手高级Java四轮面试题:设计模式+红黑树+Java锁+Redis等
快手Java一面(一个小时十分钟) 1.自我介绍 2.说说B+树和B树的区别,优缺点等? 3聊聊Spring,主要IOC等等 4多线程JUC包下的一些常见的类,比如CountDownLatch.Sem ...
- 为什么有红黑树?什么是红黑树?看完这篇你就明白了
为什么要有红黑树 想必大家对二叉树搜索树都不陌生,首先看一下二叉搜索树的定义: 二叉搜索树(Binary Search Tree),或者是一棵空树,或者是具有下列性质的二叉树:若它的左子树不空,则左子 ...
- 红黑树,看不懂你找我
文章目录 一:什么是红黑树 二:关于红黑树的一般操作 1.查找操作 2. 插入操作 2.1 新节点:我是红色的,我爹是红色的,我叔叔是黑色的 2.2 新节点:我是红色的,我爹是红色的,我叔叔也是红色的 ...
- 没有找到真爱的要看!找到真爱的人更要看!不看后悔一生
请进来的人,耐心看完这个故事! 男孩和女孩是在网上认识的,男孩很懂事,女孩很任性!女孩问男孩,你歌声好听么?男孩说,别人唱歌要钱,我唱歌要命!女孩笑着又问,知道猪是怎么死的吗?他开玩笑说跟你一样笨死 ...
- java红黑树_JAVA学习-红黑树详解
1.定义 红黑树是特殊的二叉查找树,又名R-B树(RED-BLACK-TREE),由于红黑树是特殊的二叉查找树,即红黑树具有了二叉查找树的特性,而且红黑树还具有以下特性: 1.每个节点要么是黑色要么是 ...
- JAVA:红黑树详解
点击蓝色"程序猿DD"关注我 回复"资源"获取独家整理的学习资料! 本文转载自公众号:乱敲代码 1.定义 红黑树是特殊的二叉查找树,又名R-B树(RED-BLA ...
- 死磕Java并:J.U.C之ConcurrentHashMap红黑树转换分析
作者:chessy 来源:Java技术驿站 在[死磕Java并发]-----J.U.C之Java并发容器:ConcurrentHashMap一文中详细阐述了ConcurrentHashMap的实现过程 ...
- 高级数据结构研究-B树系列以及红黑树
程序员做的越久,越发觉得基本功显得越来越重要了.基本功不扎实会潜移默化的影响你的程序开发,这不是,上次浏览博客,看到了一篇运用B+树实现数据库索引的功能,当时就不明白了,看似毫无关系的两者,怎么会有联 ...
- 这篇文章带你彻底理解红黑树
写在前面 当在10亿数据进行不到30次比较就能查找到目标时,不禁感叹编程之魅力!人类之伟大呀! -- 学红黑树有感. 终于,在学习了几天的红黑树相关的知识后,我想把我所学所想和所感分享给大家.红黑树是 ...
最新文章
- Date类(java.util)和SimpleDateFormat类(java.text)
- 实现Java Socket 客户端服务端交互实例
- ASP.NET里的变量命名规则
- 实战struts2——用户登录
- Maven3版本的超级POM位置及中央仓库位置
- win10的11对战平台突然无法启动魔兽
- python 求 gamma 分布_python如何生成各种随机分布图
- 武侠人士的10大绝招
- mysql union (all) 后order by的排序失效问题解决
- mobi格式电子书_中英文电子书下载网站大搜罗
- mysql frm idb_mysql/mariadb的数据恢复。没有libdata1,只有frm和idb文件的innodb的数据恢复...
- 三年之期已至,加多宝如何续写上市新故事
- 你会用微信付款码支付吗?一定要打开这个设置,保障你资金安全
- 嵌入式系统开发笔记15:CJ/T-188 冷热量表协议解析4
- 23.本地服务Services
- 《游戏学习》街头霸王HTML游戏源码
- 关系数据库——关系操作和关系完整性
- 6T SRAM的基本结构及其读写操作
- [循证理论与实践] Meta分析系列之五:贝叶斯 Meta 分析与 WinBUGS 软件
- 女 大三,抱金砖~呵~
热门文章
- MATLAB之矩阵分解
- OPPO连续点击android版本9,oppo游戏中心下载安装正版
- 达芬奇17for mac(DaVinci Resolve Studio 17)兼容big sur!达芬奇如何设置中文?
- 网络协议划分、各协议位于哪一层、三次握手四次挥手
- Lambda表达式接口更新方法引用函数式接口Stream流
- ruoyi是怎么点击菜单跳转页面的_电商后台设计:系统管理、菜单管理
- python 语法 tip 知识集合 常更新,以防忘记
- android 11 机型,安卓11支持机型介绍-安卓11正式版支持机型大全
- php查看CPU信息,Linux_Linux中如何查看CPU的信息,top命令是Linux下常用的性能分 - phpStudy...
- FOX-Toolkit: Introduct