数据结构(7)

B树

B树中允许一个节点拥有多个key。设定参数M,构造B树

1.每个结点最多右M-1个key,并且以升序排列

2.每个结点最多右M个子结点

3.根节点至少右两个子结点

通过磁盘预读,将数据放到B树中,3层B树可容纳1024*1024*1024差不多10亿个数据,查询数据只需要小于3次硬盘读取即可,B树大大提高了 IO的操作效率。

B+树

B+树是B树的变形:

1.非叶子结点仅有索引功能,只存储key,不存储value

2.树的所有结点构成一个有序链表,可通过key排序遍历全部数据。

在数据库中,查询操作最为常见,为了提高效率,可基于某张表的某个字段建立索引,即可提高查询效率,而这个索引就是在B+树上实现的。

B+的优点在于:

1.非叶子结点不含数据,只作为索引,在内存相同情况下,可存放更多的key;

2.B+树叶子节点相互连接,对整棵树的遍历只需要一次线性遍历即可。便于区间查询和搜索,而B树需要每一层遍历。

B树的优点在于:

1.每个结点都含有key和value,只要找到key就找到value。而B+树需要查到最大深度才能得到value

相关推荐
元亓亓亓9 小时前
考研408--数据结构--day11--最小生成树&最短路径问题&拓扑排序&关键路径
数据结构·考研·最小生成树·拓扑排序·最短路径·关键路径
Java面试题总结9 小时前
浅析二叉树、B树、B+树和MySQL索引底层原理
数据结构·b树·mysql
小比特_蓝光9 小时前
string类的模拟实现
数据结构·c++·算法
404未精通的狗9 小时前
(数据结构)AVL树
数据结构
云深处@10 小时前
【数据结构】顺序表
数据结构
Дерек的学习记录18 小时前
C++:入门基础(下)
开发语言·数据结构·c++·学习·算法·visualstudio
程序员酥皮蛋21 小时前
hot 100 第二十四题 24.回文链表
数据结构·链表
仟濹1 天前
【算法打卡day7(2026-02-12 周四)算法:BFS and BFS】 3_卡码网107_寻找存在的路线_并查集
数据结构·算法·图论·宽度优先
数智工坊1 天前
【数据结构-排序】8.2 冒泡排序-快速排序
数据结构
芝士爱知识a1 天前
[2026深度测评] AI期权交易平台推荐榜单:AlphaGBM领跑,量化交易的新范式
开发语言·数据结构·人工智能·python·alphagbm·ai期权工具