首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

B B- B+ B*

实际使用的B都是在原B的基础上加上平衡算法,即“平衡二叉”;如何保持B结点分布均匀的平衡算法是平衡二叉的关键;平衡算法是一种在B中插入和删除结点的策略; B- 是一种多路搜索(并不是二叉的...M/2的结点;删除结点时,需将两个不足M/2的兄弟结点合并; B+        B+B-的变体,也是一种多路搜索:        1.其定义基本与B-同,除了:        2.非叶子结点的子树指针与关键字个数相同...B+的搜索与B-也基本相同,区别是B+只有达到叶子结点才命中(B-可以在 非叶子结点命中),其性能也等价于在关键字全集做一次二分查找;     B+的特性:        1.所有关键字都出现在叶子结点的链表中...B+的变体,在B+的非根和非叶子结点再增加指向兄弟的指针; ?   ...分配新结点的概率比B+要低,空间使用率更高; 小结 B:二叉,每个结点只存储一个关键字,等于则命中,小于走左结点,大于走右结点; B-:多路搜索,每个结点存储M/2到M个关键字,非叶子结点存储指向关键字范围的子结点

1.6K70
您找到你想要的搜索结果了吗?
是的
没有找到

多叉 & B & B+ & B*

(2). 2-3-4: 和2-3的区别就是,它还允许节点有三个元素且有四个子节点。 4. BB是balance,平衡的意思,所以,B首先是一棵平衡,而平衡首先得是一棵排序数。...所以B就是一棵平衡的、排序的多叉B的相关说明如下: B的阶:节点的最多子节点个数叫做阶。...比如2-3的阶就是3,2-3-4的阶就是4; B的搜索:从根节点开始,对节点内的元素进行二分查找,如果找到就结束,否则进入查找元素所属范围的子节点再进行二分查找,直到找到或者到达叶子节点; B的所有节点都会存放数据...B+B+B的变体,和B的区别就是,B+所有数据都存放在叶子节点。...B+一般用于文件系统; 6. B*B*又是B+的变体,就是在B+的基础上,在非根非叶子节点之间增加了指向兄弟节点的指针。

1.5K20

B B+ B* 谈到R

插入以下字符字母到一棵空的B 中(非根结点关键字数小了(小于2个)就合并,大了(超过4个)就分裂):C N G A H E K Q M F W L T Z D P R X Y S,首先,结点空间足够,...c点么?...为了进一步详细讨论删除的情况,再举另外一个实例: 这里是一棵不同的5序B,那咱们试着删除C ? 于是将删除元素C的右子结点中的D元素上移到C的位置,但是出现上移元素后,只有一个元素的结点的情况。...在这张图中,我们的目标是删除记录c。首先使用FindLeaf操作找到c所处在的叶子结点的位置——R11。...当c从R11删除时,R11就只有一条记录了,少于最小条目数2,出现下溢,此时要调用CondenseTree操作。这样,c被删除,R11剩余的条目——指向记录d的指针——被插入链表Q。

2.1K10

【数据结构】BB+B*

一、B 1.B的定义 1. 在内存中搜索效率高的数据结构有AVL,红黑,哈希表等,但这是在内存中,如果在外部存储设备中呢?...(1)在插入节点时,B+的第一步就与B不同了,因为B的所有结点都可以存储关键字和value值,所以当B为空进行插入时,只需要创建一个根节点,然后将第一个值插入进去即可,但B+是将索引和关键字分开了...(3)B+的分裂虽然比B实现起来要简单,但B+的插入要比B多考虑一种情况,由于B+非叶子节点存储的是索引,所以有一种特殊的情况就是当在最左边最下面的叶子节点插入一个小于当前叶子结点中所有关键字的...在实际使用中,BB+的使用率是最高的,而B *用的是最少的,B *B+相比只是空间利用率更高了,但在磁盘中空间是管够的啊,所以B *实际中并不那么实用,因为磁盘根本不缺空间。...B可以看作是有序数组+平衡搜索,而B+可以看做成有序数组+平衡搜索+单链表,B*可以看作一棵节点存储的更加丰满,空间利用率更高的B+。 三、BB+的应用 1.

9621

红黑BB+

B/B+ B 即:多路平衡查找B 的巧妙之处在于: 将一个节点的大小设置为一页的大小; 一个节点可以存放多个关键字(多叉); 自平衡; 这 3 点结合起来就可以做到: 一个节点大小为一页,...B/B+的索引数量 B 的节点中存储:指针、关键字(主键)、数据 B+ 的非叶子节点:指针、关键字 B+的叶子节点:指针(链表)、关键字、数据 注意,这里不是绝对的,比如有的 B+ 中叶子节点存储的不是数据...而且上述是假设数据为 1KB,如果数据没那么大,高度为 3 的 B 能存储更多的数据,但是如果用在大型数据库索引上还是不够。 B+ B+ 如上图,B+的核心在于非叶子节点不存储数据。...B/B+的优点 更适合磁盘存储,减少了的层级,进而减少 I/O 次数; B B+ 对比 都是 B ,但是 B+更适合范围查询,比如 Mysql,且查询次数很稳定,为 logn。...而 B 更适合键值对型的聚合数据库,比如 MongoDB,查询次数最优为 O(1); 红黑更适合内存存储,B 更适合键值对存储,B+ 适合范围查询;

80740

BB+

BB+都是用于外查找的数据结构,都是平衡多路查找。 两者的区别 在B+中,具有n个关键字的结点含有n棵子树,即每个关键字对应一颗子树;而在B中,具有n个关键字的结点含有(n+1)棵子树。...在B+中,除根节点外,每个结点中的关键字个数n的取值范围是[m/2]~m,根节点n的取值范围是2~m;而在B中,除根节点外,其他所有非叶结点的关键字个数n的取值范围是[m/2]-1~m-1,根节点n...B+中的所有叶结点包含了全部关键字,即其他非叶结点中的关键字包含在叶结点中;而在B中,关键字是不重复的。...B+中的所有非叶结点仅起到索引的作用,即结点中的每个索引项只含有对应子树的最大关键字和指向该子树的指针,不包含该关键字对应记录的存储地址;而在B中,每个关键字对应一个记录的存储地址。...通常在B+树上有两个头指针,一个指向根节点,另一个指向关键字最小的叶结点,所有叶结点链接成一个不定长的线性链表,所以B+可以进行随机查找和顺序查找;而B只能进行随机查找。

84741

红黑BB+

B/B+ B 即:多路平衡查找B 的巧妙之处在于: 将一个节点的大小设置为一页的大小; 一个节点可以存放多个关键字(多叉); 自平衡; 这 3 点结合起来就可以做到: 一个节点大小为一页,...B/B+的索引数量 B 的节点中存储:指针、关键字(主键)、数据 B+ 的非叶子节点:指针、关键字 B+的叶子节点:指针(链表)、关键字、数据 注意,这里不是绝对的,比如有的 B+ 中叶子节点存储的不是数据...而且上述是假设数据为 1KB,如果数据没那么大,高度为 3 的 B 能存储更多的数据,但是如果用在大型数据库索引上还是不够。 B+ B+ 如上图,B+的核心在于非叶子节点不存储数据。...B/B+的优点 更适合磁盘存储,减少了的层级,进而减少 I/O 次数; B B+ 对比 都是 B ,但是 B+更适合范围查询,比如 Mysql,且查询次数很稳定,为 logn。...而 B 更适合键值对型的聚合数据库,比如 MongoDB,查询次数最优为 O(1); 红黑更适合内存存储,B 更适合键值对存储,B+ 适合范围查询;

65900

图解:什么是B-B+B*

什么是B B,即B-treeB是Balanced首字母,平衡的意思 因为B的原英文名称为B-tree 很多人喜欢把B-tree译作B-,然后读作B 其实,这么是不对的 容易让人会以为B...B-是两种树 特此声明:B-就是指的B 好了,本章结束 ?...什么是B+ B+B-的变体,也是一种多路搜索 4.1 B+的特点 其定义基本和特性与B-同,除了: 1.非叶子结点的子树指针与关键字个数相同 2.非叶子结点的子树指针P[i],指向关键字值属于...什么是B*B+的变体,在B+的非根和非叶子结点再增加指向兄弟的指针 B*定义了非叶子结点元素个数至少为(2/3)*M,即块的最低使用率为2/3(代替B+的1/2) B*的查询、插入和删除操作和...,且只出现一次,非叶子结点可以命中; B+:在B-基础上,为叶子结点增加链表指针,所有关键字都在叶子结点中出现,非叶子结点作为叶子结点的索引;B+总是到叶子结点才命中; B*:在B+基础上,为非叶子结点也增加链表指针

8.1K43

数据结构之BB+B*

在计算机科学中,BB+B*是常用的数据结构,它们在数据库索引、文件系统等领域发挥着重要作用。本文将深入探讨这三种树形结构的原理、特性以及应用场景。 1....B的基础概念 1.1 B的定义 B是一种平衡的搜索,通常被广泛应用于数据库和文件系统中。其定义包括以下关键特点: 多路性: 每个节点可以拥有多个子节点。...以上是B基础概念的一个简要介绍,接下来将深入探讨B+B*的特性和应用。 2. B+的特性和应用 2.1 B+的定义 B+是在B的基础上进行改进的一种数据结构。...B*的优化和应用 3.1 B*的定义 B*是在B+的基础上进行了一些优化的数据结构。其目标是减少B+树节点的分裂和合并操作,以提高性能和降低维护成本。...3.2 B*的特性 3.2.1 非叶子节点的关键字个数更多 相对于B+B*的非叶子节点可以包含更多的关键字。这一特性减少了的高度,提高了查找效率。

10510

B

B是为磁盘或其他存取的辅助存储设备而设计的一种平衡搜索B类似于红黑,但是在降低磁盘I/O方面表现很好。   B和红黑不同之处在于B的节点可以有很多孩子,从数个到数千个。...B的严格高度可能比一棵红黑的高度要小很多,因此可以使用B数在O(lgn)内完成一些动态集合的操作。   如果B的一个内部节点x包含x.n个关键字,那么节点x就要x.n+1个孩子。...B的定义 一棵BT是具有以下性质的有根(树根表示为T.root)    1.每个节点x具有下面的性质:     (1)x.n,当前存储在节点x中的关键字的个数;     (2)x.n个关键字本身...2.每个内部节点x还包含x.n+1个指向孩子的指针x.c1,x.c2,...,x.cn+1,叶节点没有孩子,所以ci属性没有定义。   ...B的高度 B树上大部分操作所需的磁盘存取次数与B的高度成正比。 查找元素的例子 ?

1.4K110

B +

# B + # 什么是 B + B + 是在二叉查找的基础上进行了改造:中的节点并不存储数据本身,而是只是作为索引。每个叶子节点串在一条链表上,链表中的数据是从小到大有序的。...那如何降低的高度呢? 我们来看下,如果我们把索引构建成 m 叉,高度是不是比二叉要小呢?...# 为什么需要 B + 关系型数据库中常用 B+ 作为索引,这是为什么呢? 思考以下经典应用场景 根据某个值查找数据,比如 select * from user where id=1234 。...实际上,数据库索引所用到的数据结构跟跳表非常相似,叫作 B+ 。不过,它是通过二叉查找演化过来的,而非跳表。...B + 的应用场景 # 参考资料 数据结构与算法之美 数据结构 二叉 B+

34330

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券