红黑树是一种二叉平衡查找树,每个结点上有一个存储位来表示结点的颜色,可以是red或black。
红黑树具有以下性质:
(1) 每个结点是红色或是黑色
(2) 根结点是黑色的
(3) 如果一个结点是红色的,则它的两个儿子都是黑色的
(4) 对于每个结点,从该结点到其子孙结点的所有路径上包含相同数目的黑结点
通过红黑树的性质,可以保证所有基于红黑树的实现都能保证操作的运行时间为对数级别(范围查找除外。它所需的额外时间和返回的键的数量成正比)。
java的treemap就是通过红黑树实现的。
红黑树的操作如果不画图很容易搞糊涂,下面通过图示来说明红黑树的插入操作。
插入一个红色的节点到红黑树中之后,会有6种情况:图示中n表示插入的节点,p表示父节点,u表示叔叔节点,g表示祖父节点,x表示当前操作节点
代码如下:
相关文章
猜你喜欢
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10






