B树的最大/最小高度

B树的最大/最小高度(基于标准定义)

B树的高度定义为 根节点到叶子节点的路径长度(根节点高度=1,叶子节点在同一层),核心依赖参数:

  • m:B树的 (每个节点最多有 m 个子节点,即最多 m-1 个关键字);
  • n:B树中存储的 总关键字数

一、最小高度(最平衡情况)

当B树每个节点都填满关键字时(除根节点外,其余节点关键字数达到最大值 m-1),高度最小。

推导逻辑:
  • 根节点最少有 1 个关键字、2 个子节点(m≥2,否则退化为单链表);
  • 2 层:2 个节点,每个最多 m-1 个关键字,总关键字数 ≤ 2*(m-1)
  • h 层:2*(m-1)^(h-2) 个节点(叶子节点),总关键字数 ≤ 2*(m-1)^(h-1) - 1(等比数列求和)。
公式:

hmin=⌈log⁡m(n+1)⌉ h_{\text{min}} = \lceil \log_m(n + 1) \rceil hmin=⌈logm(n+1)⌉

  • 示例:m=4(4阶B树,每个节点最多3个关键字),n=10 → hmin=⌈log⁡4(11)⌉=2h_{\text{min}} = \lceil \log_4(11) \rceil = 2hmin=⌈log4(11)⌉=2(第1层根节点3个关键字,第2层3个节点各3个关键字,共12个,可容纳10个)。

二、最大高度(最不平衡情况)

当B树每个非根节点仅含最少关键字时(最少 ⌈m/2⌉ - 1 个关键字,对应 ⌈m/2⌉ 个子节点),高度最大。

关键参数:
  • 最小子节点数 t = ⌈m/2⌉(称为B树的 最小度数 ),即每个非根节点至少有 t 个子节点、t-1 个关键字。
推导逻辑:
  • 根节点:1个关键字,2 个子节点;
  • 2 层:至少 2 个节点,每个 t-1 个关键字;
  • h 层:至少 2*t^(h-2) 个叶子节点,总关键字数 ≥ 2*(t-1)*(t^(h-2) - 1)/(t - 1) + (t-1) = 2*t^(h-1) - t(等比数列求和)。
公式:

hmax=⌊log⁡t(n+12)+1⌋ h_{\text{max}} = \lfloor \log_t\left( \frac{n + 1}{2} \right) + 1 \rfloor hmax=⌊logt(2n+1)+1⌋

  • 示例:m=4t=2,每个非根节点最少1个关键字、2个子节点),n=10 → hmax=⌊log⁡2((10+1)/2)+1⌋=⌊log⁡2(5.5)+1⌋=3h_{\text{max}} = \lfloor \log_2((10+1)/2) + 1 \rfloor = \lfloor \log_2(5.5) + 1 \rfloor = 3hmax=⌊log2((10+1)/2)+1⌋=⌊log2(5.5)+1⌋=3(第1层1个,第2层2个,第3层4个,共7个节点,可容纳10个)。

核心总结

场景 高度公式(t=⌈m/2⌉ 核心条件
最小高度 hmin=⌈log⁡m(n+1)⌉h_{\text{min}} = \lceil \log_m(n + 1) \rceilhmin=⌈logm(n+1)⌉ 所有节点关键字数最大化
最大高度 hmax=⌊log⁡t(n+12)+1⌋h_{\text{max}} = \lfloor \log_t\left( \frac{n+1}{2} \right) + 1 \rfloorhmax=⌊logt(2n+1)+1⌋ 非根节点关键字数最小化
关键备注:
  1. m 的定义:部分教材将"每个节点最多 m 个关键字"称为 m 阶B树,此时公式需调整(将上述 m 替换为 m+1),核心逻辑一致;
  2. 高度定义:若根节点高度定义为0,公式需减1,本质不影响高度范围;
  3. 实用性:B树的实际高度接近最小高度(因插入/删除操作会维持平衡),确保查询效率为 O(log⁡mn)O(\log_m n)O(logmn)。
相关推荐
爱敲代码的TOM19 分钟前
数据结构总结
数据结构
皮皮哎哟2 小时前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
堕2743 小时前
java数据结构当中的《排序》(一 )
java·数据结构·排序算法
2302_813806223 小时前
【嵌入式修炼:数据结构篇】——数据结构总结
数据结构
Wei&Yan3 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
long3164 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
张张努力变强7 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
wWYy.7 小时前
数组快排 链表归并
数据结构·链表
李斯啦果7 小时前
【PTA】L1-019 谁先倒
数据结构·算法
Mr Xu_1 天前
告别硬编码:前端项目中配置驱动的实战优化指南
前端·javascript·数据结构