当前位置: 首页 > java >正文

B树和B+树

一棵m阶B树,或者是空树,或者满足如下特性

1. 树中每个节点最多有m棵子树,且至多有m-1个关键字

2.若根节点不是叶子节点,那么至少两棵子树,至少一个关键字

3.除了根节点以外的节点,每个非叶节点至少有m/2向上取整棵子树

4.所有叶子节点(在B树中视为外部结点)都在同一个层面上

5.各个结点内关键字按照升序或者降序排列

B树所有结点都包含信息

B树的插入,如果一个结点插入后关键字个数为m,那就需要进行分裂,如果影响到了根节点,会使得B树高度加一

分裂的具体过程,将中间的数提到上面即可,然后两边结点进行分裂

最多需要3h+1次IO操作(影响到根节点)

B树的删除,如果一个结点删除后关键字个数小于最少个数,那么就需要进行合并

删除的步骤:

        1. 直接删除关键字(如果删除后没有破坏B树的性质)

        2. 破坏了,兄弟够借,就是将兄弟的一个元素放到父亲,然后父节点的一个元素降落下来

        3.兄弟不够借,那就将父亲的一个结点和自己的兄弟合并起来

在B+树中

1.每个关键字对应一棵子树

2.每个结点的关键字范围是m/2向上取整<=n<=m

3.叶子结点包含全部关键字,叶子结点包含信息,非叶子结点索引只包含对应子树最大关键字和指向该子树的指针

B+树的非叶子结点仅起到索引作用,查找成功需要查找到叶子结点,即每次查找长度都相同(保证查找公平性)

B+树支持顺序查找,所有叶子结点类似于一个链表结构

B树和B+树都能够有效支持随机查找

http://www.xdnf.cn/news/5060.html

相关文章:

  • xxl-job的pg数据库改造适配
  • TiDB预研-分页查询、连接查询、执行计划
  • yolov5基础--yolov5源码阅读(common.py)
  • LeRobot 项目部署运行逻辑(六)——visualize_dataset_html.py/visualize_dataset.py
  • 4-37:某单位分配到一个地址块 136.23.12.64/26。现在需要进一步划分为4个一样大的子网。试问:....
  • 全局异常未能正确捕获到对应的异常
  • shell脚本基础详细学习(更新中)
  • 资产月报怎么填?资产月报填报指南
  • 半导体供应链集成使用EDI,RosettaNet,及自定义API 之间的差异
  • 【Light】帕多瓦大学超表面技术:开启矢量光束相位偏振定制新时代
  • (pnpm)引入 其他依赖失败,例如‘@element-plus/icons-vue‘失败
  • 如何保证Session的一致性
  • temu采购自养号全流程解析:从账号搭建到安全下单的技术闭环
  • lvm详细笔记
  • 【AI论文】ZeroSearch:在不搜索的情况下激励LLM的搜索能力
  • 前端学习(1)—— 使用HTML编写一个简单的个人简历展示页面
  • VBA -- 学习Day4
  • 软件安全(二)优化shellcode
  • 使用React实现调起系统相机功能
  • 2025.05.07-淘天研发岗-第二题
  • goFrame框架中如何实现文件的excel导出
  • Spring Boot快速开发:从零开始搭建一个企业级应用
  • 普通IT的股票交易成长史--20250509 缺口(1)
  • LeetCode难题解析:数字字符串的平衡排列数目
  • 阻焊工艺如何保障多层PCB可靠性?5大核心功能与工艺控制要点
  • 深入理解 Istio 的工作原理 v1.26.0
  • 计算机网络:深度解析基于链路状态的内部网关协议IS-IS
  • OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——gmp
  • 赛季7靶场 - Environment
  • 死锁的形成