算法导论 之 B树(B-树) - 创建、插入[C语言]

本文介绍了B树的数据结构及其在计算机科学中的应用,详细讲解了B树的创建和插入操作,包括B树的节点结构定义、创建空树、插入关键字时的分裂处理等步骤,适合对数据结构感兴趣的读者学习。
摘要由CSDN通过智能技术生成


1 引言

  In computer science, a B-tree is a tree data structure that keeps data sorted and allows searches, sequential access, insertions, and deletions in logarithmic time. The B-tree is a generalization of a binary search tree in that a node can have more than two children (Comer 1979, p. 123). Unlike self-balancing binary search trees, the B-tree is optimized for systems that read and write large blocks of data. It is commonly used in databases and filesystems.


  在计算机科学中,B树在查找、访问、插入、删除操作上时间复杂度为O(log2~n)(2为底数 n为对数),与自平衡二叉查找树不同的是B树对大块数据读写的操作有更优的性能,其通常在数据库和文件系统中被使用。

  一棵m阶的B树,或为空树,或为满足下列特征的m叉树:

    ①、树中每个结点至多有m棵子树;

    ②、若根结点不是终端结点,则至少有2棵子树;

    ③、除根之外,所有非终端结点至少有棵子树;

    ④、所有的非终端结点中包含下列信息数据:

[n, C0, K0, C1, K1, C2, K2, ...., Kn-1, Cn]

        其中:Ki[i=0,1,...,n-1]为关键字,且Ki<Ki+1[i=0, 1, ..., n-2];Ci[i=0,1,...,n]为至上子树根结点的指针,且指针Ci所指子树中所有结点的关键字均小于Ki[i=0,1,...,n-1],但都大于Ki-1[i=1,...,n-1];


2 编码实现

2.1 结构定义

  根据m阶B树的性质,B树的相关结构定义如下:

/* B树结点结构 */
typedef struct _btree_node_t
{
    int num;                        /* 关键字个数 */
    int *key;                       /* 关键字:所占空间为(max+1) - 多出来的1个空间用于交换空间使用 */
    struct _btree_node_t **child
  • 23
    点赞
  • 62
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值