B树的性质和查找、插入、删除操作

m阶B树的性质:

  1. 一个节点最多有m棵子树(也就是m个子节点),非根节点最少 棵子树,根节点最少2棵子树

  2. 一个节点最多存放 m-1 个数据

  3. 顺序性:中序遍历序列是有序的;每个节点中的数据要有序排放。

  4. 所有的叶子节点都在同一层(绝对平衡)

  5. 终端节点:内部节点的最后一层 称为终端节点,终端节点的孩子就是外部节点(叶子节点null)

B树的操作:查找 插入 删除

查找:类似BST的查找

插入:

法一:插入到终端节点,若满了就分裂节点,被分裂节点的第个数据传给父节点。若此时父节点也满了就继续分裂并上传。根节点满了也分裂并上传,产生一个新的根节点。

法二:在被插入数据往下查找的过程中,发现哪个节点满了,就主动分裂。

删除关键字k:

1)查找k所在的位置x节点

2)若x是非终端节点,找k的中序遍历后继数据k1及k1所在的节点x1,k1替换k,问题转化为在x1节点中删除k1;

若x是终端节点:

a)x中删除k,x中关键字个数>=下限,结束

b)兄弟够借:至少有一个兄弟的关键字个数>下限,找这个兄弟借一个关键字。借关键字的过程:将父亲节点中的关键字下移给x,兄弟中借的关键字给父亲。

c)兄弟不够借:两个兄弟关键字个数=下限。此时,合并一个兄弟,合并时把父亲中的一个对应关键字也一起合并。父亲少一个关键字,在对父亲执行判断调整

相关推荐
流年如夢1 小时前
顺序表(LeetCode)
c语言·数据结构·leetcode·职场和发展
say_fall1 小时前
校招必看:八大排序算法原理、复杂度与高频面试题
数据结构·c++·算法·排序算法
浅念-14 小时前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
im_AMBER17 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵
如君愿17 小时前
考研复习 Day 30 | 习题--计算机网络 第五章(运输层 上)、数据结构 图(上)
数据结构·计算机网络·课后习题
weixin_4217252617 小时前
C语言中volatile关键字怎么用C语言volatile在多线程中的作用
c语言·数据结构·运算符优先级·变量命名·volatile关键字
05候补工程师19 小时前
【408 从零到一】线性表逻辑特征、存储结构对比与 C/C++ 动态内存分配避坑指南
c语言·开发语言·数据结构·c++·考研
努力努力再努力wz20 小时前
【MySQL 进阶系列】拒绝滥用root:从 mysql.user 到权限校验,带你彻底理解用户管理与授权机制!
android·c语言·开发语言·数据结构·数据库·c++·mysql
炸膛坦客20 小时前
嵌入式 - 数据结构与算法:(1-4)数据结构 - 单链表的两个核心缺点(引入循环/双向链表)
c语言·数据结构·链表
Hesionberger21 小时前
LeetCode 78:子集生成全攻略
java·开发语言·数据结构·python·算法·leetcode·职场和发展