news 2026/5/12 14:23:30

哈希表是一种基于映射关系的存储结构,其核心是哈希函数 $ H(key) $,它将任意关键字转换为地址空间内的索引值,从而实现快速存取

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
哈希表是一种基于映射关系的存储结构,其核心是哈希函数 $ H(key) $,它将任意关键字转换为地址空间内的索引值,从而实现快速存取

B-树的插入与删除操作需严格维护其结构平衡性。在插入时,首先将关键字插入到合适的叶节点中,若该节点关键字数量超过上限 $ m-1 $,则进行“分裂”:取中间关键字上移至父节点,原节点以中间关键字为界拆分为两个子节点。若分裂传递至根节点且导致根满,则根分裂并生成新的根,树高加一。删除操作时,若关键字位于非叶节点,则用其中序后继替代并转为对叶节点的删除;若删除后节点关键字个数小于最小要求 $ \lceil m/2 \rceil - 1 $,则通过左兄弟或右兄弟“借”关键字,若兄弟也无法借用,则与兄弟及父节点中的分隔关键字合并,可能导致合并后的节点继续向上合并,甚至树高减一。

哈希表是一种基于映射关系的存储结构,其核心是哈希函数 $ H(key) $,它将任意关键字转换为地址空间内的索引值,从而实现快速存取。理想情况下查找时间复杂度为 $ O(1) $。但由于哈希函数输出空间有限,不同关键字可能映射到同一地址,产生冲突。常见的冲突解决方法包括链地址法(拉链法)和开放定址法(如线性探测、平方探测)。为减少冲突,应设计分布均匀的哈希函数,并保持较低的装载因子。
当B-树中某节点的关键字个数超过 $ m-1 $(即最大允许关键字数)时,需对该节点进行分裂操作,以维持B-树的结构特性。具体步骤如下:

  1. 确定分裂位置
    将该节点中的 $ m $ 个关键字按升序排列(插入后已有序),选取中间关键字(第 $ \lceil m/2 \rceil $ 个关键字,即索引为 $ \left\lfloor \frac{m}{2} \right\rfloor $ 的关键字)作为上移关键字。

  2. 拆分左右两部分

    • 中间关键字左侧的 $ \lceil m/2 \rceil - 1 $ 个关键字保留在原节点中;
    • 右侧的 $ \lfloor m/2 \rfloor $ 个关键字构成一个新节点;
    • 若该节点是非叶节点(有子树),则其 $ m+1 $ 棵子树也需一并分割:前 $ \lceil m/2 \rceil $ 棵子树归属原节点,后 $ \lfloor m/2 \rfloor + 1 $ 棵子树归属新节点。
  3. 中间关键字上移至父节点
    将选出的中间关键字插入到父节点中的合适位置,并将新节点的指针作为右子树连接到父节点中。若父节点因此也超过了 $ m-1 $ 个关键字,则递归执行分裂,直至根节点。

  4. 若根节点分裂
    当根节点发生分裂时,创建一个新的根节点,将上移的关键字作为新的根,原根分裂为两个子节点。此时树的高度增加一层。

⚠️ 注意:分裂操作保证了每个节点的关键字个数始终满足 $ \lceil m/2 \rceil - 1 \leq n \leq m-1 $,从而保持B-树的平衡性。

# 示例伪代码表示分裂过程(以m=5为例)defsplit_node(node):mid=len(node.keys)//2# m=5时,mid=2,第3个关键字上移separator=node.keys[mid]left_keys=node.keys[:mid]# 前半部分保留right_keys=node.keys[mid+1:]# 后半部分新建节点left_children=node.children[:mid+1]ifnotnode.is_leaf()elseNoneright_children=node.children[mid+1:]ifnotnode.is_leaf()elseNonenew_right_node=BTreeNode(keys=right_keys,children=right_children)# 更新当前节点node.keys=left_keys node.children=left_childrenreturnseparator,new_right_node

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 4:57:10

C++网络模块设计实战(兼容性增强秘籍)

第一章:C网络模块设计的核心挑战在构建高性能、高可靠性的C网络应用时,网络模块的设计面临诸多底层技术挑战。这些挑战不仅涉及并发模型的选择,还包括资源管理、错误处理和跨平台兼容性等多个方面。异步I/O与事件驱动架构 现代网络服务需同时…

作者头像 李华
网站建设 2026/5/10 17:49:26

组件化设计 vs 继承体系,哪种更适合C++游戏引擎的长期扩展?

第一章:C游戏引擎扩展性的核心挑战在现代游戏开发中,C 依然是构建高性能游戏引擎的首选语言。然而,随着项目规模的增长,如何保持引擎的可扩展性成为开发者面临的核心难题。一个优秀的游戏引擎不仅要满足当前功能需求,还…

作者头像 李华
网站建设 2026/5/4 3:37:35

深入LLVM后端优化(Clang 17性能调优全解析)

第一章:深入LLVM后端优化(Clang 17性能调优全解析)在现代C开发中,Clang 17结合LLVM后端提供了强大的编译时优化能力。通过精细控制代码生成与优化策略,开发者能够在不修改源码的前提下显著提升程序性能。LLVM的模块化设…

作者头像 李华
网站建设 2026/5/9 9:15:37

谷歌镜像网站访问困难?这里提供HunyuanOCR替代下载通道

腾讯HunyuanOCR:轻量级端到端OCR的国产化新选择 在企业数字化转型加速推进的今天,文档信息提取早已不再是“能不能识别文字”的问题,而是“能否快速、准确、安全地完成结构化解析”的挑战。尤其是在跨境办公、政务处理和金融合规等场景中&am…

作者头像 李华
网站建设 2026/5/3 6:11:39

PHP网站添加OCR功能?HunyuanOCR为传统系统赋能

PHP网站添加OCR功能?HunyuanOCR为传统系统赋能 在企业数字化转型的浪潮中,许多基于PHP构建的传统Web系统——比如老旧的内容管理系统、表单提交平台或内部管理后台——正面临一个尴尬的现实:它们每天处理大量扫描件、发票截图、身份证照片甚至…

作者头像 李华
网站建设 2026/5/3 3:41:08

长尾词挖掘:‘pycharm激活码永’之外的AI模型流量入口

长尾词挖掘:“pycharm激活码永”之外的AI模型流量入口 在搜索引擎的角落里,总能搜到一些奇怪又熟悉的关键词——“pycharm激活码永久免费”“vscode破解补丁下载”……这些长尾词背后,是开发者对工具成本的高度敏感。但你有没有想过&#xff…

作者头像 李华