算法基础 -- 小根堆构建的两种方式:上浮法与下沉法

news2025/5/17 8:05:18

小根堆构建的两种方式:上浮法与下沉法

在构建小根堆(Min-Heap)时,通常有两种常见的构建方式:

  1. 上浮建堆(逐个插入,上浮调整)
  2. 下沉建堆(Heapify 自底向上,下沉调整)

这两种方法在时间复杂度上有显著差异。


一、上浮建小根堆:逐个插入 + 上浮调整

1. 核心原理:

  • 对于给定的无序数组,逐个插入到堆中。

  • 每次插入新元素时,将其放在堆的最后一个位置(末尾),然后执行“上浮”调整:

    • 将新元素与其父节点比较,如果新元素更小,则与父节点交换。
    • 重复此过程,直到新元素达到正确的位置或成为堆顶。

2. 上浮过程示例:

  • 对于每个新插入的元素,最多需要调整至堆顶。
  • 在完全二叉树中,高度为 ⌊ log ⁡ n ⌋ \lfloor \log n \rfloor logn
  • 因此,单个元素上浮的时间复杂度为 O ( log ⁡ n ) O(\log n) O(logn)

3. 总体时间复杂度分析:

  • 对于 n n n 个元素,逐个插入,每次上浮调整:

    O ( 1 × log ⁡ 1 ) + O ( 1 × log ⁡ 2 ) + ⋯ + O ( 1 × log ⁡ n ) O(1 \times \log 1) + O(1 \times \log 2) + \cdots + O(1 \times \log n) O(1×log1)+O(1×log2)++O(1×logn)

  • 这相当于一个对数级数求和:

    ∑ i = 1 n log ⁡ i ≈ O ( n log ⁡ n ) \sum_{i=1}^{n} \log i \approx O(n \log n) i=1nlogiO(nlogn)

  • 结论:上浮建堆的时间复杂度为 O ( n log ⁡ n ) O(n \log n) O(nlogn)


二、下沉建小根堆:Heapify 自底向上

1. 核心原理:

  • 直接将无序数组视为一个完全二叉树。

  • 从最后一个非叶子节点开始,逐个向前进行“下沉”调整:

    • 对当前节点执行下沉:

      • 与左右子节点中较小的一个交换,确保当前节点保持小根堆性质。
    • 重复下沉,直到当前节点满足堆性质或成为叶节点。

2. 下沉过程示例:

  • 对于每个非叶子节点进行下沉操作。

  • 下沉操作的时间取决于树的高度:

    • 对于完全二叉树,树高为 ⌊ log ⁡ n ⌋ \lfloor \log n \rfloor logn

    • 但下沉的层次是逐级减少的:

      • n / 2 n/2 n/2 个节点(叶节点)不需要下沉。
      • n / 4 n/4 n/4 个节点下沉 1 次。
      • n / 8 n/8 n/8 个节点下沉 2 次。
      • ……

3. 总体时间复杂度分析:

  • 这是一种渐进减半的过程

    ∑ i = 1 log ⁡ n n 2 i × i \sum_{i=1}^{\log n} \frac{n}{2^i} \times i i=1logn2in×i

  • 该求和公式的复杂度为 O ( n ) O(n) O(n),这是因为下沉过程中的递减效果:

T ( n ) = 2 × n 2 × 1 + 2 × n 4 × 2 + 2 × n 8 × 3 + ⋯ ≈ O ( n ) T(n) = 2 \times \frac{n}{2} \times 1 + 2 \times \frac{n}{4} \times 2 + 2 \times \frac{n}{8} \times 3 + \cdots \approx O(n) T(n)=2×2n×1+2×4n×2+2×8n×3+O(n)

  • 结论:下沉建堆的时间复杂度为 O ( n ) O(n) O(n)

三、两种建堆方式的时间复杂度对比

建堆方式上浮建堆(逐个插入)下沉建堆(Heapify)
原理逐个插入,上浮调整自底向上,下沉调整
调整过程每次上浮至正确位置从最后一个非叶节点下沉
复杂度 O ( n log ⁡ n ) O(n \log n) O(nlogn) O ( n ) O(n) O(n)

四、为什么下沉建堆更高效?

  • 下沉建堆(Heapify)直接从中间节点开始调整,避免了对叶子节点的重复操作。
  • 叶子节点天生满足堆的性质,因此可以忽略。
  • 而上浮建堆在每次插入时都进行上浮,无法利用已经部分有序的特性,导致较高的复杂度。

五、实际应用中的选择:

  • 上浮建堆: 常用于动态增量插入堆的情况(如优先队列逐个入队)。
  • 下沉建堆: 常用于一次性构建堆(如堆排序)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2377479.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LED接口设计

一个LED灯有3种控制状态,常亮、常灭和闪烁,要做到这种控制最简单的一种方法是使用任何一款处理器的普通IO去控制。 用IO控制方式有两种,一种是高有效,如下图1所示IO口为高电平时LED亮,IO为低电平时LED不亮。IO口出一个…

SpringBoot项目使用POI-TL动态生成Word文档

近期项目工作需要动态生成Word文档的需求,特意调研了动态生成Word的技术方案。主要有以下两种: 第一种是FreeMarker模板来进行填充;第二种是POI-TL技术使用Word模板来进行填充; 以下是关于POI-TL的官方介绍 重点关注&#xff1…

YOLOv3深度解析:多尺度特征融合与实时检测的里程碑

一、YOLOv3的诞生:继承与突破的起点 YOLOv3作为YOLO系列的第三代算法,于2018年由Joseph Redmon等人提出。它在YOLOv2的基础上,针对小目标检测精度低、多类别标签预测受限等问题进行了系统性改进。通过引入多尺度特征图检测、残差网络架构和独…

uniapp-商城-60-后台 新增商品(属性的选中和页面显示)

前面添加了属性,添加属性的子级项目。也分析了如何回显,但是在添加新的商品的时,我们也同样需要进行选择,还要能正常的显示在界面上。下面对页面的显示进行分析。 1、界面情况回顾 属性显示其实是个一嵌套的数据显示。 2、选中的…

虹科技术 | 简化汽车零部件测试:LIN/CAN总线设备的按键触发功能实现

汽车零部件测试领域对操作的便捷性要求越来越高,虹科Baby-LIN-RC系列产品为这一需求提供了完美的解决方案。从基础的按键设置到高级的Shift键应用,本文将一步步引导您了解虹科Baby-LIN-RC系列产品的智能控制之道。 虹科Baby-LIN-3-RC 想象一下&#xff0…

单片机ESP32天气日历闹铃语音播报

自制Arduino Esp32 单片机 可以整点语音播报,闹铃语音播报,农历显示,白天晚上天气,硬件有 Esp32,ST7789显示屏,Max98357 喇叭驱动,小喇叭一枚。有需要源码的私信我。#单片机 #闹钟 #嵌入式 #智能…

如何解决LCMS 液质联用液相进样器定量环漏液问题

以下是解决安捷伦1260液相色谱仪为例的进样器定量环漏液问题的一些方法:视频操作 检查相关部件 检查定量环本身:观察定量环是否有破损、裂纹或变形等情况。如果发现定量环损坏,需及时更换。检查密封垫:查看进样阀的转子密封垫、计…

服务器内部可以访问外部网络,docker内部无法访问外部网络,只能docker内部访问

要通过 iptables 将容器中的特定端口请求转发到特定服务器,你需要设置 DNAT(目标地址转换)规则。以下是详细步骤: 假设场景 容器端口: 8080(容器内服务监听的端口)目标服务器: 192.168.1.100(请…

PCIe Switch 问题点

系列文章目录 文章目录 系列文章目录完善PCIe Retimer Overview Document OutlineSwitch 维度BroadComMicroChipAsmedia 祥硕Cyan其他 完善 Functional block diagram,功能框图Key Features and Benefits,主要功能和优点Fabric 链路Multi-root PCIe Re…

开源轻量级地图解决方案leaflet

Leaflet 地图:开源轻量级地图解决方案 Leaflet 是一个开源的 JavaScript 库,用于在网页中嵌入交互式地图。它以轻量级、灵活性和易用性著称,适用于需要快速集成地图功能的项目。以下是关于 Leaflet 的详细介绍和使用指南。 1. Leaflet 的核心…

Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件

目录 1. 创建Flutter项目 1.1使用Android Studio创建Flutter项目 1.2 使用命令行创建Flutter项目 2. Flutter项目介绍 2.1所有代码都在lib目录下编写 2.1 pubspec.yaml 依赖库/图片的引用 ​编辑 3. 运行项目 4. 编写mian.dart文件 4.1 使用MaterialApp 和 Scaffold两个组件…

如何实现金蝶云星空到MySQL的数据高效集成

金蝶云星空数据集成到MySQL的技术案例分享 在企业信息化建设中,数据的高效流动和准确处理是关键。本文将聚焦于一个具体的系统对接集成案例:金蝶云星空的数据集成到MySQL,方案名称为“xsck-2金蝶销售出库-->mysql”。通过这一案例&#x…

院校机试刷题第四天:1911反转公约数、1702十六进制不进位加法

一、1911反转公约数 1.题目描述 2.解题思路 两个关键点:1.如何把数字反转,2.如何求最大公约数。 反转:用字符串形式存储,定义一个新的字符串倒序存储反转之后的字符串,将字符串按位转换位数字。 求最大公约数&…

Redis解析

Redis解析 一、单线程模型 redis在io层面是多线程的,在数据处理层面是单线程的。 多线程一般用于: 关闭连接删除/淘汰内存网络IO 1.1 io多路复用 redis使用nio(select、poll、epoll)的方式处理socket 主线程负责接收建立连接…

2025年Ai写PPT工具推荐,这5款Ai工具可以一键生成专业PPT

上个月给客户做产品宣讲时,我对着空白 PPT 页面熬到凌晨一点,光是调整文字排版就改了十几版,最后还是被吐槽 "内容零散没重点"。后来同事分享了几款 ai 写 PPT 工具,试完发现简直打开了新世界的大门 —— 不用手动写大纲…

css:倒影倾斜效果

这是需要实现的效果,平时用的比较多的是添加阴影,是box-shadow,而添加倒影是box-reflect,需要注意的是box-reflect需要添加浏览器前缀,比如我用的谷歌浏览器,要加-webkit-才能生效。 -webkit-box-reflect:…

语音识别——通过PyAudio录入音频

PyAudio 是一个用于处理音频的 Python 库,它提供了录制和播放音频的功能。通过 PyAudio,可以轻松地从麦克风或其他音频输入设备录制音频,并将其保存为文件或进行进一步处理。 安装 PyAudio 在使用 PyAudio 之前,需要先安装它。可…

五月月报丨MaxKB在教育行业的应用进展与典型场景

在2025年的3月和4月的“用户应用月度报告”中,MaxKB开源项目组相继总结了MaxKB开源项目在政府、公共事业、教育、医疗以及企事业单位的应用情况。毫无疑问,在DeepSeek等国产大模型被各行各业的用户广泛接受之后,AI应用建设并运营的步伐也在显…

【流程控制结构】

流程控制结构 流程控制结构1、顺序结构2、选择结构if基本选择结构if else语法多重if语法嵌套if语法switch选择结构 3、循环结构循环结构while循环结构程序调试for循环跳转语句区别 流程控制结构 1、顺序结构 流程图 优先级 2、选择结构 if基本选择结构 单if 语法 if&…

PowerBI基础

一、前言 在当今数据驱动的时代,如何高效地整理、分析并呈现数据,已成为企业和个人提升决策质量的关键能力。Power BI 作为微软推出的强大商业智能工具,正帮助全球用户将海量数据转化为直观、动态的可视化洞察。数据的世界充满可能性&#xf…