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)。
相关推荐
LYFlied3 小时前
【每日算法】LeetCode 153. 寻找旋转排序数组中的最小值
数据结构·算法·leetcode·面试·职场和发展
jianfeng_zhu5 小时前
整数数组匹配
数据结构·c++·算法
yueqingll5 小时前
032、数据结构之代码时间复杂度和空间复杂度的判断:从入门到实战
数据结构
罗湖老棍子9 小时前
最小函数值(minval)(信息学奥赛一本通- P1370)
数据结构·c++·算法··优先队列·
LYFlied9 小时前
【每日算法】LeetCode 208. 实现 Trie (前缀树)
数据结构·算法·leetcode·面试·职场和发展
AI科技星10 小时前
统一场论框架下万有引力常数的量子几何涌现与光速关联
数据结构·人工智能·算法·机器学习·重构
仰泳的熊猫10 小时前
1109 Group Photo
数据结构·c++·算法·pat考试
2401_8414956410 小时前
【数据结构】最短路径的求解
数据结构·动态规划·贪心·ipython·最短路径·迪杰斯特拉算法·弗洛伊德算法
tgethe10 小时前
Java 数组(Array)笔记:从语法到 JVM 内核
java·数据结构
客梦11 小时前
数据结构-单链表
数据结构