文章目录
此处提供一个红黑树在线生成网站:Red/Black Tree Visualization
一、简介
红黑树的引入
有了二叉搜索树,为什么还需要平衡二叉树?
- 二叉树容易退化成一条链
- 此时查询的时间复杂度也由O(log2N)将退化成O(N)
- 而平衡二叉树对左右子树高度差有限制,保证最坏的时间复杂度为O(log2N)
有了平衡二叉树,为什么还要红黑树?
- AVL的左右子树高度差不能超过1,每次进行插入/删除操作时,几乎都需要通过旋转操作保持平衡
- 在频繁进行插入/删除的场景中,频繁的旋转操作使得AVL的性能大打折扣
- 红黑树通过牺牲严格的平衡,换取插入/删除时少量的旋转操作,整体性能优于AVL
- 红黑树插入时的不平衡,不超过两次旋转就可以解决;删除时的不平衡,不超过三次旋转就能解决
- 红黑树的红黑规则,保证最坏的情况下,也能在O(log2N)时间内完成查找操作。
红黑树简介
红黑树是一种自平衡的二叉查找树,是一种高效的查找树。它是由 Rudolf Bayer 于1978年发明,在当时被称为平衡二叉 B 树(symmetric binary B-trees)
。后来,在1978年被 Leo J. Guibas 和 Robert Sedgewick 修改为如今的红黑树
。红黑树具有良好的效率,它可在O(l