- 1、本文档共38页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构第7章2
* 7.5 B_树 内搜索:当集合足够小,可以驻留在内存中,搜索在内存中进行,无需访问外存。 内存中的集合用AVL树表示能够获得很好的性能。对于较大的集合,它们必须存储在磁盘上。 外搜索:在外存中搜索给定关键字的元素的方法。 外存中,集合可以用B-树表示。 第七章 集合与搜索树 7.1 集合及其表示 7.3 二叉搜索树 7.4 二叉平衡树 7.5 B_树 7.5.1 m叉搜索树 1. M叉搜索树的定义 m叉搜索树或者是一棵空树,或者是一棵满足下列特性的树: ⑴ 根结点最多有m棵子树,并具有如下结构: n,P0,(K1,P1),(K2,P2),…,(Kn,Pn) 其中,Pi是指向子树的指针,0? i? n m, Ki是关键字值,1?i?nm。 ⑵ KiKi+1 , 1?in ⑶ 子树Pi上的所有关键字值都大于Ki,小于Ki+1,0in。 ⑷ 子树P0上的所有关键字值都小于K1, 子树Pn上的所有关键字值都大于Kn。 ⑸ 子树Pi(0? i?n)也是m叉搜索树。 2. m叉搜索树的例子 图中的小方块代表空树,空树也常被视为“失败结点”,因为这是当搜索某个关键字值x不在树中时到达的子树。失败结点不包含元素。 根结点有两个孩子,树中结点内的关键字依次排列,孩子数最多为4,所以为四叉搜索树。 3. m叉搜索树的搜索方法 在四叉搜索树中搜索关键字值为53的元素。 4. m叉搜索树的高度、结点数 高度为h的m叉搜索树中 ⑶ 一棵有N个元素的m叉搜索树的高度在logm(N+1)到N之间。 ⑴ 结点数最多为: ⑵ 元素个数最多为:mh-1 (每个结点最多m-1个元素) 7.5.2 B_树的定义 一棵m阶B_树是一棵m叉搜索树,它或者是空树,或者是满足下列特性的树: ⑴ 根结点至少有两个孩子。 ⑵ 除根结点和失败结点外的所有结点至少有?m/2?个孩子。 ⑶ 所有失败结点均在同一层上。 注意:B树定义中的m, ?m/2?都是针对孩子的,而不是元素。 m阶B树中: ⑴ 结点最多有m个孩子; ⑵ 结点最少有?m/2?个孩子; ⑶ 根结点最少有两个孩子。 7.5.3 B-树的高度 1. B-树的性质 证明:设非失败结点的总数为n,一个非失败结点中的元素数为ni,指针数为pi,0i=n,则 而B树所有非失败结点的指针数为n+s-1,即 N=(n+s-1)- n = s-1 性质得证。 一棵B-树包含的元素总数N是B-树的失败结点的总数s 减一,即N=s-1。 2. B-树的高度的性质 证明:根据B_树的定义:第1层: 至少1个结点;第2层: 至少2个结点;第3层: 除根外,每个结点至少?m/2?个孩子, 故第三层至少2 ?m/2?个结点;…第h层: 至少有?m/2? h-2个结点;第h+1层: 至少2 (?m/2?)h-1个结点; h+1层是失败结点。若m阶B-树有N个元素,则失败结点的个数为s=N+1≥2(?m/2?)h-1,所以有: 7.5.4 B-树的搜索 B-树的搜索算法与m叉搜索树的搜索算法相同。 在4阶B-树中搜索关键字值为53和42的元素。 7.5.5 B-树的插入 1. B-树的插入 将一个元素插入B-树,首先要检查B-树中是否包含相同关键字的元素,如果存在则插入操作失败。否则将新元素插在搜索失败的最下层非失败结点,即叶子结点中。 2. B-树结点的插入算法(设为结点q) ⑴ 若该结点未满,即结点中包含的元素个数不足m-1,则只需按有序表中插入一个新元素的方法插入之。 ⑵ 若该结点已满,则必须进行结点的分裂操作。 分裂发生在?m/2?处。设新结点的地址为q’,那么关键字值为K?m/2?的元素和地址q’将插入结点q的双亲结点中。 ⑶ 如果被分裂的结点是根结点,那么分裂产生的两个结点的指针q和q’以及关键字为K?m/2?的元素应建成一个新的根结点。这时,B-树会长高。 1.查找新元素的插入结点q(一定是最下层的非失败结点)2.(1)若q结点未满 (2)若q结点已满,分裂操作。 (插入新元素后,结点的第?m/2?个元素) 3. B-树插入的例子:插入53(p131) 图7.22 B-树插入53后的情况 7.5.6 B-树的删除 1. B-树的删除 如果被删除的元素不在叶子结点中,那么由它的右边的子树上最左下方的结点中的最小元素取代之,即由大于被删除的元素的最小元素取代之。这种替代使得删除操作归结为总是从叶子结点中删除一个元素的问题,即叶子结点中。 当一个结点中的元素数大于?m/2?-1时
文档评论(0)