前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >你好,我是B树

你好,我是B树

作者头像
WindWant
发布2021-07-23 16:15:27
3020
发布2021-07-23 16:15:27
举报
文章被收录于专栏:后端码事后端码事

一、什么是B树?

B树是一棵是具备以下特点的有根树

1、节点属性

a)x.n:为节点中存储的关键字个数

b)x.key:为节点中存储的关键字。x.key1、x.key2 ... x.keyx.n 以非降序顺序排列,满足 x.key1 <= x.key2 ... <= x.keyx.n。

c)x.leaf:为当前节点是否为叶子节点(true | false)

d)x.c:为指向子节点的指针,内部节点包含指针个数为 x.n + 1,叶子节点没有子节点,所以没有此属性。

2、分割

关键字 x.key 对存储在子树中的关键字进行分割。某个子节点的所有关键字值范围总是在节点 x 的某两个关键字之间。这个值可能是任何可排序的表示,比如:

3、深度

每个叶子节点具有相同的深度,即树的高度(由根节点到叶子节点的路径长度)。

4、度数

每个节点包含的关键字个数有上下界限制。基本表示单位为B树的最小度数 t(满足 t >= 2):

a)除了根节点外(空树没有关键字,非空树根节点至少包含一个关键字),每个节点至少有 t - 1 个关键字,进而可以推导,每个内部节点至少有 t 个子节点【1.d】。

b)每个节点至多包含 2t - 1 个关键字(此时称之为【满】 状态),进而可以推导,每个内部节点至多有 2t 个子节点【1.d】。

二、B数的高度

首先树的根节点至少包含 1 个关键字,其它节点至少包含 t - 1 个关键字,至少有 t 个子节点【一.4.a】。

我们知道 B 树的度数 t >= 2,所以:

深度为 1 的位置上至少有 2 个节点。

深度为 2 的位置至少有 2 * t 个 节点。

深度为 3 的位置至少有 2 * t * t 个 节点。

... ...

深度为 h 的位置至少有 2 * t * ... * t 个 节点。

图示:

【1】所以所有非根节点个数至少为:2 + 2 * t + 2 * t * t + 2 * t * ... * t = 2 * t0 + 2 * t1+ 2 * t2 + 2 * th-1,标识为 sum(node)

【2】相应的非根节点关键字个数至少为:(t - 1) * sum(node)

【3】那么总的关键字个数至少为: 1 + (t - 1) * sum(node)

【4】我们用 n 表示关键字个数,所以存在 n >= 1 + (t - 1) * sum(node),代入【1】中的求和,最终经过一系列的变换,可以得出B树的高度满足:h <= logt(n+1)/2

三、B树的搜索

假定我们要查找的关键字为 k,入口节点 x:

a)需要找到 k 在 x 所有关键字中的位置,临界关键字 keyi 满足 k <= keyi

b)如果存在 k == keyi 那么查找结束,否则继续。

c)如果 x 为叶子节点,则查找结束,否则继续

d)由 keyi 临界关键字,我们可以得到相应指向子节点的指针 ci

然后,继续由 ci 指向的子节点作为入口节点,继续上述过程。

四、B树的插入

B树插入新关键字后,必须仍然是一颗合法的B树。

由【一.4.b】我们直到 B 树节点存在一种状态【满】,即当前节点关键字个数为 2t -1。【满】状态的节点插入新节点必须经过特定的前置处理:分裂

所谓分裂,即将节点由中间关键字作为分割点,分割为两个节点,每个节点包含 t - 1 个关键字,中间节点 x.kt 则上升到父节点中,作为两棵子树的划分点,参见【一.2】。

此处需要注意的是,如果父节点同样为【满】节点,那么在分割点上升之前,同样需要对父节点执行【分裂】操作。

满节点的分裂行为会沿着树向上传播直到不再需要分裂为止

上面我们描述的过程,是一个自下而上的【满】状态分裂传播行为。

我们知道,要实现节点的插入,首先需要经过一个B树的搜索查找的过程,搜索过程自上而下

显然,两个过程,有些重复,我们需要的是单向查找插入。

鉴于此,在执行查找的过程中,遇到路径上的满节点,则执行分裂操作,直到找到位置插入节点,这样就避免了自下而上的【分裂】传播行为。

五、B树的删除

B树删除特定关键字后,必须仍然是一颗合法的B树。

B树的插入是一个对节点最大关键字数量的约束满足过程,相应的,B树的删除是一个对节点最小关键字数量的约束满足过程

保障沿途节点关键字数量至少为度数 t,一遍自根而下执行删除。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-07-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、什么是B树?
    • 1、节点属性
      • 2、分割
        • 3、深度
          • 4、度数
          • 二、B数的高度
          • 三、B树的搜索
          • 四、B树的插入
          • 五、B树的删除
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档