4.红黑树
红黑树
- 红黑树是一种自平衡的
二叉查找树
,属于AVL平衡树的一种特殊形式
特征:
- 每个节点要么是红色,要么是黑色。
- 根节点是黑色。
- 每个叶子节点(NIL)是黑色。
- 如果一个节点是红色,则其两个子节点必须是黑色。
- 从任一节点到其每个叶子的所有路径,都包含相同数目的黑色节点。
红黑树的这5条性质,使得一棵n个结点是红黑树始终保持了logn的高度
解决了AVL树的什么问题:
- AVL的左右子树高度差不能超过1,每次进行插入/删除操作时,几乎都需要通过旋转操作保持平衡
- 在频繁进行插入/删除的场景中,频繁的旋转操作使得AVL的性能大打折扣
- 红黑树通过牺牲严格的平衡,换取插入/删除时少量的旋转操作,整体性能优于AVL。红黑树插入时的不平衡,不超过两次旋转就可以解决;删除时的不平衡,不超过三次旋转就能解决
- 红黑树的红黑规则,保证最坏的情况下,也能在O(log 2N)时间内完成查找操作
本文作者:navyum
本文链接:https://www.cnblogs.com/navyum/p/18509359
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步