B树知识点总结

B树知识点总结

1. 基本概念

  • B树是一种自平衡的m叉查找树,主要用于减少磁盘I/O操作
  • "B"可能代表balanced(平衡)、broad(宽)或Bayer(发明者姓氏)
  • 所有叶子节点位于同一层,保证了查询效率

2. B树特性

  • 每个节点最多有m个子节点(m为B树阶数)
  • 除根节点外,每个节点至少有**⌈m/2⌉个子节点**
  • 根节点至少有2个子节点(除非是叶子节点)
  • 一个节点包含k个关键字,则该节点有k+1个子节点指针
  • 节点内部关键字按升序排列,起到分隔子树的作用

3. B树操作

搜索

  • 从根节点开始,在节点内进行线性/二分查找
  • 根据比较结果选择对应的子树继续搜索

插入

  • 先找到合适的叶子节点并插入关键字
  • 节点溢出(关键字数>m-1)时需要分裂:
    • 将中间关键字提升到父节点
    • 剩余关键字分为两个节点
    • 可能递归向上处理,根节点溢出会增加树高

删除

  • 在叶子节点直接删除
  • 在非叶子节点用前驱/后继替换后删除
  • 节点下溢(关键字数<⌈m/2⌉-1)时需要调整:
    • 从兄弟节点借关键字
    • 与兄弟节点合并
    • 可能递归向上处理,根节点下溢会减少树高

4. B树变种

  • B+树:所有数据记录存储在叶子节点,叶子节点间有指针相连,广泛应用于数据库索引
  • B*树:要求非根节点至少2/3满,空间利用率更高

5. 应用场景

  • 数据库索引系统(如MySQL的InnoDB引擎)
  • 文件系统(NTFS、ext4等)
  • 大规模数据存储系统

6. 复杂度分析

  • 搜索、插入、删除时间复杂度:O(logₘn)
  • 空间复杂度:O(n)
  • 由于m通常很大(100+),B树高度很低,极大减少了I/O次数

7. 与二叉搜索树的区别

  • B树是多路平衡查找树,更适合磁盘等块存储设备
  • B树节点大小通常设计为与磁盘块大小匹配
  • B树高度更低,但节点内部需要顺序/二分查找

B树的核心价值在于优化了磁盘I/O操作,通过降低树高和增加节点容量,极大提高了大规模数据存储和检索的效率。

相关推荐
张张努力变强2 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
wWYy.2 小时前
数组快排 链表归并
数据结构·链表
李斯啦果2 小时前
【PTA】L1-019 谁先倒
数据结构·算法
Mr Xu_18 小时前
告别硬编码:前端项目中配置驱动的实战优化指南
前端·javascript·数据结构
czxyvX18 小时前
017-AVL树(C++实现)
开发语言·数据结构·c++
数智工坊18 小时前
【数据结构-队列】3.2 队列的顺序-链式实现-双端队列
数据结构
elseif12318 小时前
【C++】并查集&家谱树
开发语言·数据结构·c++·算法·图论
徐小夕@趣谈前端19 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Nebula_g19 小时前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
xuxie9920 小时前
day 23 树
数据结构