B树是一种平衡的多路查找树,一棵m阶B树或为空树,或满足下列特性:

1、  每个节点之多有m棵子树

2、  若根节点不是叶子节点,则至少有两颗子树

3、  除根之外所有非终端节点至少有[m/2]可子树([]是上取整)

4、  所有非终端节点中包含下列信息数据:(n,A0,K1,A1,K2,A2,….,Kn,An),其中n为关键码数目,ki均为关键码,Ai为指向子树的指针,Ai中的所有关键码均在区间[ki,ki+1]中。

5、  所有终端节点均在同一层次,可将终端节点的的下一层成为叶子节点或失败节点,查找到叶子节点意味着查找失败

对于m阶B树

简单口诀:插入时,多了就分;删除时,不够就借,借不到就合

解释:插入时,当一个节点的关键码数目等于m时则分裂,选取中间的关键码上升为父节点中的一个关键码,其余的左右两侧分别作为其左右子树,由于父节点关键码数目增加,若有需要向上递归解决;

注意:新插入的关键码必然是从叶子节点开始,分裂也是从叶子节点开始

删除一个关键码,有两种情形:

情形一:关键码所在节点不是叶子节点,找到关键码的后继节点x来替换,x必然属于叶子节点,现在问题成了删除叶子节点x了,参考情形二。

情形二:待删除的关键码x属于叶子节点,若x是根节点,直接删除;x不是根节点,当关键码数量n大于[m/2]-1,直接删除; 若n等于[m/2]-1,则向左右兄弟借,如果左右兄弟的关键码数目有一个大于[m/2]-1,则借其一个;如果左右兄弟的关键码数目均等于[m/2]-1, 选择一个合并,父节点中的一个关键码也下降到合并节点中了,此时父节点关键码数目减少,递归解决;

性能分析:令 a=[m/2], 高度为h的B树最少节点数目为

1 + 2* { (a-1) + (a-1)a + (a-1)a^2 + …(a-1)a^(h-2) } = 2a^(h-1) -1 = 2[m/2]^(h-1)

最多节点数目为 (m-1) + (m-1)*m +(m-1)*m^1 + … + (m-1)*m^(h-1) =  m^h -1;

查找复杂即为其高度大约为 以a为底n的对数,n为节点数目,按照最大高度计算;

B+树,与B树不同之处:

(1)       所有关键码都存放在叶子节点

(2)       有n棵子树的节点有n个关键码

(3)       上层的关键码复写到对应子树,作为最大(最小)关键码

其他不同之处:

B+树有两个头指针,一个纸箱B+树的根节点,一个指向关键码最小的叶节点,因此在B+树上可以进行树搜索和顺序搜索,在树搜索过程中,如果非叶节点上的关键码等于给定值,搜索并不定制,而是继续沿右指针向下一直到叶节点上的关键码;

B+树插入和删除只在叶节点进行,合并和分裂与B树相同,注意更新关键码,删除时上层副本可以保留作为“分界关键码”

B树总结的更多相关文章

  1. B树——算法导论(25)

    B树 1. 简介 在之前我们学习了红黑树,今天再学习一种树--B树.它与红黑树有许多类似的地方,比如都是平衡搜索树,但它们在功能和结构上却有较大的差别. 从功能上看,B树是为磁盘或其他存储设备设计的, ...

  2. ASP.NET Aries 入门开发教程8:树型列表及自定义右键菜单

    前言: 前面几篇重点都在讲普通列表的相关操作. 本篇主要讲树型列表的操作. 框架在设计时,已经把树型列表和普通列表全面统一了操作,用法几乎是一致的. 下面介绍一些差距化的内容: 1:树型列表绑定: v ...

  3. 再讲IQueryable<T>,揭开表达式树的神秘面纱

    接上篇<先说IEnumerable,我们每天用的foreach你真的懂它吗?> 最近园子里定制自己的orm那是一个风生水起,感觉不整个自己的orm都不好意思继续混博客园了(开个玩笑).那么 ...

  4. HDU1671——前缀树的一点感触

    题目http://acm.hdu.edu.cn/showproblem.php?pid=1671 题目本身不难,一棵前缀树OK,但是前两次提交都没有成功. 第一次Memory Limit Exceed ...

  5. 算法与数据结构(十一) 平衡二叉树(AVL树)

    今天的博客是在上一篇博客的基础上进行的延伸.上一篇博客我们主要聊了二叉排序树,详情请戳<二叉排序树的查找.插入与删除>.本篇博客我们就在二叉排序树的基础上来聊聊平衡二叉树,也叫AVL树,A ...

  6. [C#] C# 知识回顾 - 表达式树 Expression Trees

    C# 知识回顾 - 表达式树 Expression Trees 目录 简介 Lambda 表达式创建表达式树 API 创建表达式树 解析表达式树 表达式树的永久性 编译表达式树 执行表达式树 修改表达 ...

  7. bzoj3207--Hash+主席树

    题目大意: 给定一个n个数的序列和m个询问(n,m<=100000)和k,每个询问包含k+2个数字:l,r,b[1],b[2]...b[k],要求输出b[1]~b[k]在[l,r]中是否出现. ...

  8. bzoj1901--树状数组套主席树

    树状数组套主席树模板题... 题目大意: 给定一个含有n个数的序列a[1],a[2],a[3]--a[n],程序必须回答这样的询问:对于给定的i,j,k,在a[i],a[i+1],a[i+2]--a[ ...

  9. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  10. jquery-treegrid树状表格的使用(.Net平台)

    上一篇介绍了DataTable,这一篇在DT的基础之上再使用jquery的一款插件:treegrid,官网地址:http://maxazan.github.io/jquery-treegrid/ 一. ...

随机推荐

  1. Windows7环境下Apache连接MySQL提示“连接已重置”的解决办法

    win7下手动搭建wamp环境,碰到的几个坑总结下, 1.能正常访问php和html类型文件,但是访问项目文件时老是连接被重置,后来总结是数据库的问题,就写测试用例测试php能否成功调用数据库, &l ...

  2. 利用html5canvas给图片增加文字水印

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  3. CF1060D Social Circles

    思路: 贪心.既然每个人的左边是其他人的右边,每个人的右边是其他人的左边,那么使重叠的部分最多即可. 实现: #include <bits/stdc++.h> using namespac ...

  4. cf580E. Kefa and Watch(线段树维护字符串hash)

    题意 $n$个数的序列,$m + k$种操作 1.$l , r, k$把$l - r$赋值为$k$ 2.$l, r, d$询问$l - r$是否有长度为$d$的循环节 Sol 首先有个神仙结论:若询问 ...

  5. Scanner-String-StringBuilder-API

    1.能够明确API的使用步骤     1)打开帮助文档     2)点击显示,找到索引,看到输入框     3)你要找谁?在输入框里输入,然后回车     4)看包:java.lang下的类不需 ...

  6. Android ScrollView嵌套RecyclerView导致在三星s8曲面屏显示不全问题

    当RecyclerView适配显示不全时可以单独给其嵌套一个相对布局!!!(必须是相对布局),这样在曲面屏手机就可以全部显示出来如下图所示 <RelativeLayout android:lay ...

  7. c#网站对服务器的数据库的备份与还原

    在网站上备份数据库 1.前台页面 <div> 需要备份的文件名:<asp:TextBox ID="bfFile" runat="server" ...

  8. 雨林木风ghost win7 64位快速装机版V2016年

    雨林木风ghost win7 64位快速装机版V2016年2月 系统下载:http://www.xitongma.com 系统概述 雨林木风ghost win7 64位旗舰装机版自动无人值守安装,采用 ...

  9. mongodb-3.2.8 单机复制集安装

    规划: replSet 复制集名称: rs1 MongoDB数据库安装安装路径为:/usr/local/mongodb/ 复制集成员IP与端口: 节点1: localhost:28010   (默认的 ...

  10. 图像处理框架 Core Image 介绍

    这篇文章会为初学者介绍一下 Core Image,一个 OS X 和 iOS 的图像处理框架. 如果你想跟着本文中的代码学习,你可以在 GitHub 上下载示例工程.示例工程是一个 iOS 应用程序, ...