数据结构(七)——B树和B+树

7.4.1_1 B树

5叉查找树

cpp 复制代码
//5叉排序树的结点定义
struct Node {
    ElemType keys[4];          //最多4个关键字
    struct Node &child[5];     //最多5个孩子
    int num;                   //结点中有几个关键字
};

如何保证查找效率?

eg:对于5叉排序树,规定除了根节点处。任何结点都至少有3个分叉,2个关键字

策略: ①m叉查找树中,规定除了根节点外,任何结点至少有个分叉,即至少含有个关键字

②m叉查找树中,规定对于任何一个结点,其所有子树的高度都要相同。

7.4.1 B树

B树,又称多路平衡查找树,B树中所被允许的孩子个数的最大值称为B树的阶,通常用m表示。一棵m阶B树或为空树,或为满足如下特性的m叉树:

1)树中每个结点至多有m棵子树,即至多含有m-1个关键字。

2)若根结点不是终端结点,则至少有两棵子树。

3)除根结点外的所有非叶结点至少有棵子树,即至少含有个关键字。

5)所有的叶结点都出现在同一层次上,并且不带信息(可以视为外部结点或类似于折半查找判定树的查找失败结点,实际上这些结点不存在,指向这些结点的指针为空)。





7.4.1_2 B树的插入和删除

B树的插入


7.4.1_3 B+树

一棵m阶的B+树需满足下列条件:

1)每个分支结点最多有m棵子树(孩子结点)。

2)非叶根结点至少有两棵子树,其他每个分支结点至少有「m/2]棵子树。

3)结点的子树个数与关键字个数相等。

4)所有叶结点包含全部关键字及指向相应记录的指针,叶结点中将关键字按大小顺序排列,并且相邻叶结点按大小顺序相互链接起来。

5)所有分支结点中仅包含它的各个子结点中关键字的最大值及指向其子结点的指针。

B+树 VS B树

m阶B+树:

1)结点中的n个关键字对应n棵子树

2)根节点的关键字数n∈[1, m]

其他结点的关键字数

3)在B+树中,叶结点包含全部关键字,非叶结点中出现过的关键字也会出现在叶结点中

4)在B+树中,叶结点包含信息,所有非叶结点仅起索引作用,非叶结点中的每个索引项只含有对应子树的最大关键字和指向该子树的指针,不含有该关键字对应记录的存储地址。

m阶B树:

1)结点中的n个关键字对应n+1棵子树

2)根节点的关键字数n∈[1, m-1]。

其他结点的关键字数

3)在B树中,各结点中包含的关键字是不重复的

4)B树的结点中都包含了关键字对应的记录的存储地址

在B+树中,非叶结点不含有该关键字对应记录的存储地址。

可以使一个磁盘块可以包含更多个关键字,使得B+树的阶更大,树高更矮,

读磁盘次数更少,查找更快

相关推荐
Vect__10 小时前
链表漫游指南:C++ 指针操作的艺术与实践
数据结构·c++·链表
古译汉书10 小时前
蓝桥杯算法之基础知识(2)——Python赛道
数据结构·python·算法·蓝桥杯
.Vcoistnt10 小时前
Codeforces Round 1043 (Div. 3)(A-E)
数据结构·算法
野犬寒鸦10 小时前
力扣hot100:搜索二维矩阵与在排序数组中查找元素的第一个和最后一个位置(74,34)
java·数据结构·算法·leetcode·list
啊吧怪不啊吧17 小时前
C++之list类的代码及其逻辑详解 (中)
开发语言·数据结构·c++·list
楼田莉子18 小时前
C++算法学习专题:滑动窗口
开发语言·数据结构·c++·学习·算法·leetcode
zh_xuan20 小时前
LeeCode 40.组合总和II
c语言·数据结构·算法
wangluoqi20 小时前
c++ 数据结构-并查集、ST表 小总结
数据结构·c++
小马学嵌入式~1 天前
数据结构:队列 二叉树
c语言·开发语言·数据结构·算法
省四收割者1 天前
Go语言入门(10)-数组
数据结构·经验分享·笔记·vscode·算法·golang