B+ Tree

2023-10-30

什么是B+

  • B+ tree是平衡二叉树
  • 每个节点包含k个元素, k的范围在 d <= k <= 2d 之间(也就是Minimun 50% occupancy, except for root)
  • d 被叫做 the order of the tree
  • 比如d = 2,则 2 <= k <= 4, k最小是2, 保证 Minimun 50% occupancy
  • 叶子节点用链表相连
  • B+ 的主要功能是作为数据库的索引
  • 节点只存索引, 叶子节点存数据
    在这里插入图片描述

B+ 树的时间复杂度和高度

  • 时间复杂度为
    log ⁡ f N \log_{f}{N} logfN
    f = f a n o u t , N = 叶子节点 . f = fanout, N = 叶子节点. f=fanout,N=叶子节点.
  • B+树高度计算公式
    h = l o g d ′ [ ( n + 1 ) 2 d ′ ′ ] + 1 h = log_{d'}{[\frac{(n+1)} {2d''}]} + 1 h=logd[2d′′(n+1)]+1
    其中 d ′ 为内部节点的度数 , d ′ ′ 为叶子节点的度数 其中d'为内部节点的度数, d''为叶子节点的度数 其中d为内部节点的度数,d′′为叶子节点的度数

Example: 假设有3000W条数据,每个节点保存64个索引. 计算B+树的高度

  • 计算B+树的叶子节点的度数: 每个节点最多可以保存64个索引,因此叶子节点的度数也为64. 也就是 d’’ = 64
  • 计算B+树的内部节点的度数:由于B+树的叶子节点与内部节点的结构不同,因此它们的度数也不同。对于B+树的内部节点,其度数需要满足以下条件:每个节点内最少包含2个子节点(即分支数至少为2),最多包含64个子节点。因此,可以选择一个适当的度数d’,使得一个节点可以容纳足够多的子节点,同时保持树的平衡性。常见的做法是将d’设置为B+树的叶子节点度数的一半,即d’ = 32
    h = l o g 32 [ ( n + 1 ) 2 d ′ ′ ] + 1 h = log_{32}{[\frac{(n+1)} {2d''}]} + 1 h=log32[2d′′(n+1)]+1

假设有3000W条数据,每个节点保存64个索引。
那么索引的高度就是(log2^25)/log64=25/6=4

Insert

简单的insert

Insert 16.5
在这里插入图片描述
在这里插入图片描述
Insert 17
在这里插入图片描述
在这里插入图片描述

复杂的Insert

Insert 8
在这里插入图片描述

  • 左边第一个node已经满了, 则需要拆分node
  • 2 3 5 7 8 重新组成两个节点 2 3 和 5 7 8,同时需要将5放进root作为新的索引
    在这里插入图片描述
  • root此时也满了 5 13 17 24 30, 则需要分裂root为两个新node 5 13和24 30, 17作为新的root
    在这里插入图片描述

Insert 40
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Delete

简单的delete

delete 19
在这里插入图片描述
在这里插入图片描述

复杂的delete

delete 20
在这里插入图片描述
在这里插入图片描述

  • 22这个节点元素太少, 不符合 Min 50% rule, 所以从旁边的sibling 借元素填充
    在这里插入图片描述

delete 24
在这里插入图片描述

  • 左右两边的sibling 都只有min数量的元素, 所以不能借
  • 需要合并两个节点
    在这里插入图片描述
  • 合并后父节点只剩一个元素, 所以需要将root和子节点合并在这里插入图片描述

时间复杂度

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

B+ Tree 的相关文章

  • Linux wc命令

    Linux wc命令 作用 统计字节数 字符数 行数 最长的行的长度 单词数 格式 wc OPTION FILE wc OPTION files0 from F OPTION c 或 bytes 计算字节数 m 或 chars 计算字符数
  • SPA项目开发之首页导航+左侧栏菜单

    文章目录 后台主界面搭建 左侧树收缩功能 vue总线的概念 后台主界面搭建 在搭建主界面之前 来给大家介绍一个MOCK js 是一个模拟数据的生成器 用来帮助前端调试开发 进行前后端的原型分离以及用来提高自动化测试效率 众所周知Mock j

随机推荐

  • hex码和ascii码的转换

    hex码和ascii码的转换 2017年01月09日 17 48 25 changeyourmind 阅读数 4784 版权声明 本文为博主原创文章 未经博主允许不得转载 https blog csdn net changyourmind
  • PRT(Precomputed Radiance Transfer【2002】)原理实现

    声明 本文源自对Games202课程 作业2的总结 参考 手把手教你写GAMES202作业 GAMES202 作业2 Precomputed Radiance Transfer 球谐函数 GAMES 202 作业2 Games202课程 个
  • Apache Beam 模型

    背景 Apache Beam 是Google 开源的一个统一编程框架 它本身不是一个流式处理平台 而是提供了统一的编程模型 帮助用户创建自己的数据处理流水线 实现可以运行在任意执行引擎之上批处理和流式处理任务 它包含 一个可以涵盖批处理和流
  • C++工程实践经验

    1 C 工程实践经验谈 陈硕 giantchen gmail com 最后更新 2012 4 20 版权声明 本作品采用 Creative Commons 署名 非商业性使用 禁止演绎 3 0 Unported 许可 协议 cc by nc
  • DF标志和串移动指令(movsb/movsw)

    1 标志寄存器的第10位DF 方向标志位 在串处理指令中 控制每次操作后si di的增减 DF 0 每次操作后 si di增加 DF 1 每次操作后 si di减小 我们可以用汇编语法描述movsb的功能如下 mov es di byte
  • 读写分离(主从复制,Sharding-JDBC)

    目录 1 介绍 2 配置 2 1配置准备 2 2配置主库Master 2 3配置从库Slave 3 读写分离案例 3 1Sharding JDBC 3 2入门案例 1 介绍 MySQL主从复制是一个异步的复制过程 底层是基于MySQL数据库
  • 数控直流电压源的设计与制作【keil5 & AD20]

    目录 1 设计任务与要求 1 1 设计任务 1 2 设计要求 2 设计方案 2 1 系统方案设计 2 1 1 滤波电路 2 2 2 辅助电源电路 2 2 3 三端可调稳压电路 2 2 4 电压 电流采样电路 2 2 元器件选型 2 2 1电
  • 浅析数据库case when 用法

    背景 今天在做一个需求 大致就是根据卡的logo去匹配 卡片的主卡数量 附属卡数量 激活卡数量 未激活卡数量 销卡数量等 当时以为要写很多sql 后来问了下同事说可以用case when写一条sql就能搞定 当时那个开心啊就是这样的O O哈
  • YoloV8改进策略:SPD-Conv加入到YoloV8中,让小目标无处遁形

    摘要 SPD Conv是一种新的构建块 用于替代现有的CNN体系结构中的步长卷积和池化层 它由一个空间到深度 SPD 层和一个非步长卷积 Conv 层组成 空间到深度 SPD 层的作用是将输入特征图的每个空间维度降低到通道维度 同时保留通道
  • arxiv国内镜像——快速下载

    arXiv org是一个收录科学文献预印本的在线数据库 目前包含了超过50万篇文章 并且以每个月5000篇的速度增长着 目前 这个数据库包含 数学 物理 计算机 非线性科学 定量生物学 定量财务以及统计学几大分类 其最重要的特点就是 开放式
  • php结合验证码实现登陆,thinkPHP实现的验证码登录功能示例

    本文实例讲述了thinkPHP实现的验证码登录功能 分享给大家供大家参考 具体如下 使用thinkphp自带的验证 实现登录页面的账号密码 验证码的验证 namespace Admin Controller use Think Contro
  • hashmap的扩容机制

    1 hashmap扩容的代码实现 hashMap的扩容机制 final Node
  • springboot整合IJPay实现微信支付-V3---微信小程序

    前言 微信支付适用于许多场合 如小程序 网页支付 但微信支付相对于其他支付方式略显麻烦 我们使用IJpay框架进行整合 一 IJpay是什么 JPay 让支付触手可及 封装了微信支付 支付宝支付 银联支付常用的支付方式以及各种常用的接口 不
  • Flutter

    看到有不少人在用 CustomScrollView 我实在心痛 杀鸡焉用牛刀 好好看代码 一个小小的 Column 就能解决问题 class AddHeaderFooterListPageState extends State
  • OpenCV3特征提取与目标检测之HOG(一)——HOG的概述与原理

    1 HOG Histogram of Oriented Gradient 是方向梯度直方图的意思 是一种特性描述子 通过计算与统计图像局部区域的梯度方向直方图来构成特征 边缘是图像颜色剧变的区域 在一副图像中 局部目标的表象与形状能够被梯度
  • PDU+远控,企业如何应用工业级智能PDU远程赋能业务?

    在很多企业级业务场景下 如何保障相关业务设备的稳定供电非常重要 插座也就成为了这些业务体系中的核心基建 为了保证相关设备供电的稳定 并且实现高效的远程管理 很多企业级的业务场景会部署专业的智能PDU 而在众多智能PDU设备中 向日葵智能PD
  • AI实战:钉钉 AI 的魔法棒,“小二” 帮你打工

    钉钉作为企业办公领域巨头般的存在 市场规模远超企微和飞书 随着阿里 AI 大模型的能力提升 AI 能力也在慢慢嵌入到阿里各个产品生态中去 钉钉 AI 就是在这样的一个背景下产生的 官方网站 https workspace dingtalk
  • Web项目如何做单元测试

    你可能会用单元测试框架 python的unittest pytest Java的Junit testNG等 那么你会做单元测试么 当然了 这有什么难的 test demo py def inc x return x 1 def test a
  • 在WebStorm中使用Vue的v-bind,v-on等内置指令时报命名空间的错误

    报错详情 Namespace v bind is not bound Namespace v on is not bound 等 问题说明 出现这个错误不是代码本身的问题 而是 WebStorm 这个编辑器的问题 因为 WebStorm 不
  • B+ Tree

    B Tree 什么是B B 树的时间复杂度和高度 Insert 简单的insert 复杂的Insert Delete 简单的delete 复杂的delete 时间复杂度 什么是B B tree是平衡二叉树 每个节点包含k个元素 k的范围在