美文网首页
2018-05-22

2018-05-22

作者: ROC_XU的日记本 | 来源:发表于2018-05-22 10:39 被阅读0次

    1.B-数、B+数


    B-树

    特点:

    是一种多路搜索树(并不是二叉的):

    1.定义任意非叶子结点最多只有M个儿子;且M>2;

    2.根结点的儿子数为[2, M];

    3.除根结点以外的非叶子结点的儿子数为[M/2, M];

    4.每个结点存放至少M/2-1(取上整)和至多M-1个关键字;(至少2个关键字)

    5.非叶子结点的关键字个数=指向儿子的指针个数-1;

    6.非叶子结点的关键字:K[1], K[2], …, K[M-1];且K[i] < K[i+1];

    7.非叶子结点的指针:P[1], P[2], …, P[M];其中P[1]指向关键字小于K[1]的

    子树,P[M]指向关键字大于K[M-1]的子树,其它P[i]指向关键字属于(K[i-1], K[i])的子树;

    8.所有叶子结点位于同一层;

    如:(M=3)

    B-树的搜索,从根结点开始,对结点内的关键字(有序)序列进行二分查找,如果

    命中则结束,否则进入查询关键字所属范围的儿子结点;重复,直到所对应的儿子指针为空,或已经是叶子结点;

    B-树的特性:

    1.关键字集合分布在整颗树中;

    2.任何一个关键字出现且只出现在一个结点中;

    3.搜索有可能在非叶子结点结束;

    4.其搜索性能等价于在关键字全集内做一次二分查找;

    5.自动层次控制;

    B+树

    B+ 树是一种树数据结构,是一个n叉树,每个节点通常有多个孩子,一棵B+树包含根节点、内部节点和叶子节点。根节点可能是一个叶子节点,也可能是一个包含两个或两个以上孩子节点的节点。

    用途:

    B+ 树通常用于数据库和操作系统的文件系统中。NTFS, ReiserFS, NSS, XFS, JFS, ReFS 和BFS等文件系统都在使用B+树作为元数据索引。B+ 树的特点是能够保持数据稳定有序,其插入与修改拥有较稳定的对数时间复杂度。B+ 树元素自底向上插入。

    B+树的定义

    B+树是应文件系统所需而出的一种B-树的变型树。一棵m阶的B+树和m阶的B-树的差异在于:

    1.有n棵子树的结点中含有n个关键字,每个关键字不保存数据,只用来索引,所有数据都保存在叶子节点。

    2.所有的叶子结点中包含了全部关键字的信息,及指向含这些关键字记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。

    3.所有的非终端结点可以看成是索引部分,结点中仅含其子树(根结点)中的最大(或最小)关键字。

    通常在B+树上有两个头指针,一个指向根结点,一个指向关键字最小的叶子结点。

    B+树是B-树的变体,也是一种多路搜索树:

    1.其定义基本与B-树同,除了:

    2.非叶子结点的子树指针与关键字个数相同;

    3.非叶子结点的子树指针P[i],指向关键字值属于[K[i], K[i+1])的子树(B-树是开区间);

    5.为所有叶子结点增加一个链指针;

    6.所有关键字都在叶子结点出现;

    如:(M=3)

    B+的搜索与B-树也基本相同,区别是B+树只有达到叶子结点才命中(B-树可以在

    非叶子结点命中),其性能也等价于在关键字全集做一次二分查找;

    B+的特性:

    1.所有关键字都出现在叶子结点的链表中(稠密索引),且链表中的关键字恰好是有序的;

    2.不可能在非叶子结点命中;

    3.非叶子结点相当于是叶子结点的索引(稀疏索引),叶子结点相当于是存储(关键字)数据的数据层;

    4.更适合文件索引系统;

    红黑树待续...

    相关文章

      网友评论

          本文标题:2018-05-22

          本文链接:https://www.haomeiwen.com/subject/xlchjftx.html