我正在尝试根据“算法简介”中的“B-Trees”一章来实现 B-Tree。
我不太明白的是“最低学位”。在书中指出,度数是一个数字,表示节点可以持有的键数的下限/上限。它进一步说:
- 每个非根节点至少存储
t - 1
key 并且有t
children。 - 每个节点最多存储
2*t - 1
key 并且有2*t
children。
所以你得到 t = 2:
t - 1
= 1 个键和 t = 2 个孩子2*t - 1
= 3 把钥匙和 4 个孩子
对于 t = 3
t - 1
= 2 个键和 t = 3 个孩子2*t - 1
= 5 把钥匙和 6 个孩子
现在问题来了:似乎 B-Tree 中的节点在它们已满时只能存储奇数个键。
为什么不能有一个节点,比如说最多 4 个键和 5 个子节点?它与拆分节点有关吗?