B树的性质和插入过程

性质

  1. 平衡性:所有叶子节点都在同一层
  2. 多路 :m 阶 B 树
    最多: m 个分支,m-1 个元素
    最少: 根节点 2 个分支 1个元素
    其他节点 ⌈ m / 2 ⌉ \lceil m/2\rceil ⌈m/2⌉ 个分支 ⌈ m / 2 ⌉ \lceil m/2\rceil ⌈m/2⌉ − 1 -1 −1 个元素
  3. 有序:结点内有序,左子树<根<右子树

插入过程

  1. 定位插入点:从根节点开始,逐层向下遍历B树,找到要插入的键值应该插入的位置。

  2. 在插入点插入后,检查叶子节点是否已满。如果已满,则需要进行分裂操作。

  3. 分裂操作:如果叶子节点已满(m 个点即满),将其分裂。中间的点(第 ⌈ m / 2 ⌉ \lceil m/2\rceil ⌈m/2⌉ 个点)上升为子树根节点(插入到未分裂前的根节点当中),中间点左右两端的点变为中间点的键值所在点的左右子树。若未分裂前的根节点被插入后满了,继续重复该操作

是 否 定位插入点 是否已满 分裂操作 正常插入操作

相关推荐
wengqidaifeng8 分钟前
数据结构:排序(下)---进阶排序算法详解
数据结构·算法·排序算法
wengqidaifeng13 分钟前
数据结构:排序(上)---基础排序算法详解
数据结构·算法·排序算法
Sam_Deep_Thinking9 小时前
学数据结构到底有什么用
数据结构
py有趣13 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
hipolymers13 小时前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
CS创新实验室14 小时前
从“跑得动”到“跑得稳”:深度剖析数据结构究竟是理论点缀还是核心战力?
数据结构
jllllyuz14 小时前
MATLAB 蒙特卡洛排队等待模拟程序
数据结构·matlab
自我意识的多元宇宙15 小时前
树、森林——树、森林与二叉树的转换(森林转换为二叉树)
数据结构
海清河晏11115 小时前
数据结构 | 双循环链表
数据结构·链表
py有趣15 小时前
力扣热门100题之编辑距离
数据结构·算法·leetcode