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)。
相关推荐
执携2 小时前
算法 -- 冒泡排序
数据结构·算法
wen__xvn3 小时前
代码随想录算法训练营DAY14第六章 二叉树 part02
数据结构·算法·leetcode
Ka1Yan3 小时前
[数组] - 代码随想录(2-6)
数据结构·算法·leetcode
漫随流水4 小时前
leetcode算法(104.二叉树的最大深度)
数据结构·算法·leetcode·二叉树
执携5 小时前
数据结构 -- 数组(Array)
数据结构
洛豳枭薰5 小时前
List梳理
数据结构·windows·list
星火开发设计6 小时前
C++ multiset 全面解析与实战指南
开发语言·数据结构·c++·学习·set·知识
小猪咪piggy6 小时前
【leetcode100】回溯
数据结构·算法
星火开发设计7 小时前
C++ stack 全面解析与实战指南
java·数据结构·c++·学习·rpc··知识
C雨后彩虹7 小时前
书籍叠放问题
java·数据结构·算法·华为·面试