参考资料
面试常问:什么是红黑树? https://blog.csdn.net/qq_36610462/article/details/83277524
正文
跳跃表
跳跃列表是对有序的链表增加上附加的前进链接
性质:
1.由很多层结构组成;
2.每一层都是一个有序的链表,排列顺序为由高层到底层,都至少包含两个链表节点,分别是前面的head节点和后面的nil节点;
3.最底层的链表包含了所有的元素;
4.如果一个元素出现在某一层的链表中,那么在该层之下的链表也全都会出现(上一层的元素是当前层的元素的子集);
5.链表中的每个节点都包含两个指针,一个指向同一层的下一个链表节点,另一个指向下一层的同一个链表节点;
平衡二叉树
特征:
(1)非叶子节点拥有1~2个子节点;
(2)左边子节点value<非叶子节点value<右边子节点value;
(3)任意节点的abs(左子树高度-右子树高度)<=1;
(4)没有值相等重复的节点;
常见的符合平衡二叉树的有,B树(多路平衡搜索树)、AVL树(二叉平衡搜索树)等。
AVL树
红黑树
1.根节点是黑色。
2.每个叶子节点都是黑色的空节点(NIL节点)。
3.分支节点是红色或黑色。
4 每个红色节点的两个子节点都是黑色。(为了保证从每个叶子到根的所有路径上不能有两个连续的红色节点)
5.从任一节点到其每个叶子的所有路径都包含相同数目的黑色节点。
B树
B树和平衡二叉树稍有不同的是B树属于多叉树
规则:
(1)树中的每个节点最多拥有2~m个子节点,空树除外(注:m阶代表一个树节点最多有多少个查找路径,m阶=m路,当m=2则是2叉树,m=3则是3叉);
(2)除根节点外每个节点的关键字数量大于等于ceil(m/2)-1个小于等于m-1个;(注:ceil()是个朝正无穷方向取整的函数 如ceil(1.1)结果为2)
(3)所有叶子节点均在同一层、叶子节点除了包含了关键字和关键字记录的指针外也有指向其子节点的指针只不过其指针地址都为null对应下图最后一层节点的空格子
(4)如果一个非叶节点有N个子节点,则该节点的关键字数等于N-1;
(5)所有节点关键字是按递增次序排列,并遵循左小右大原则;
B+树
规则
(1)B+跟B树不同B+树的非叶子节点不保存关键字记录的指针,这样使得B+树每个节点所能保存的关键字大大增加;
(2)B+树叶子节点保存了父节点的所有关键字和关键字记录的指针,每个叶子节点的关键字从小到大链接;
(3)B+树的根节点关键字数量和其子节点个数相等;
(4)B+的非叶子节点只进行数据索引,不会存实际的关键字记录的指针,所有数据地址必须要到叶子节点才能获取