heapq库的使用——python代码

server/2025/4/1 5:50:22/

Python中heapq库的基础使用方法和示例代码,包含详细注释说明:


1. 基本功能

heapq 实现的是最小堆(父节点值 ≤ 子节点值),核心操作包括:

  • 插入元素heappush(heap, item)
  • 弹出最小值heappop(heap)
  • 堆化列表heapify(list)(将无序列表转换为堆)
  • 查看最小值heap[0]

2. 基础示例代码

python">import heapq# 创建一个空堆
heap = []# 插入元素
heapq.heappush(heap, 3)
heapq.heappush(heap, 1)
heapq.heappush(heap, 4)print("当前堆:", heap)  # 输出: [1, 3, 4](实际存储为堆结构)# 弹出最小值
min_val = heapq.heappop(heap)
print("弹出的最小值:", min_val)  # 输出: 1
print("剩余堆:", heap)  # 输出: [3, 4]# 堆化现有列表
existing_list = [5, 2, 7, 1]
heapq.heapify(existing_list)
print("堆化后的列表:", existing_list)  # 输出: [1, 2, 7, 5]

3. 进阶用法

3.1 合并堆
python">heap1 = [1, 3, 5]
heap2 = [2, 4, 6]
merged_heap = heapq.merge(heap1, heap2)
print("合并后的堆(迭代器):", list(merged_heap))  # 输出: [1, 2, 3, 4, 5, 6]
3.2 处理复杂元素

当元素是元组时,默认按第一个元素排序。可通过tuple调整优先级:

python"># 按元组第二个元素排序(需预处理)
tasks = [(3, "任务A"), (1, "任务B"), (2, "任务C")]
heapq.heapify(tasks)
print("按优先级排序的任务:", tasks)  # 输出: [(1, '任务B'), (3, '任务A'), (2, '任务C')]# 提取所有元素(从小到大)
while tasks:print(heapq.heappop(tasks))
# 输出:
# (1, '任务B')
# (2, '任务C')
# (3, '任务A')
3.3 限制堆大小

保留堆中最大的N个元素(或最小的N个元素):

python"># 保留最小的3个元素
nums = [4, 1, 7, 3, 8, 5]
heapq.heapify(nums)
heapq.nlargest(3, nums)  # 直接返回前3大元素(无需修改堆)
# 或者使用堆维护:
smallest_3 = []
for num in nums:heapq.heappush(smallest_3, num)if len(smallest_3) > 3:heapq.heappop(smallest_3)
print("最小的3个元素:", smallest_3)  # 输出: [1, 3, 4]

4. 注意事项

  1. 堆的索引:堆的根节点在索引0,子节点在2*i+12*i+2
  2. 时间复杂度
    • 插入/弹出:O(log n)
    • 堆化列表:O(n)
  3. 直接操作堆:避免手动修改堆列表,需通过heapq函数维护堆性质。

5. 应用场景

  • 优先队列:如任务调度系统。
  • Top K 问题:快速找到前K大/小的元素。
  • 图算法:如Dijkstra算法中的优先队列。
  • 流数据处理:实时维护最大/最小值的集合。

如果需要最大堆,可以将元素取负数后存入最小堆,使用时再转换回来。


http://www.ppmy.cn/server/180194.html

相关文章

基于Spring Boot的智能新冠疫苗接种助手管理系统的设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…

Java + LangChain 实战入门,开发大语言模型应用!

在 Baeldung 上看到了一篇介绍基于 Java LangChain 开发大语言模型应用的基础入门文章,写的非常不错,非常适合初学者。于是,我抽空翻译了一下。 原文地址:https://www.baeldung.com/java-langchain-basics翻译: Java…

算法训练营第二十七天 | 贪心算法(五)

文章目录 一、Leetcode 56.合并区间二、Leetcode 738.单调递增的数字 一、Leetcode 56.合并区间 以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组&#xff…

在 i.MX8MP 上用 C++ 调用豆包 AI 大模型实现图像问答

本文介绍了如何在 i.MX8MP 嵌入式平台上使用 C 调用豆包 AI 大模型(Doubao-vision-pro-32k)进行图像问答。我们将详细讲解代码实现的各个步骤,包括文件读取、Base64 编码、构造 JSON 请求体、使用 libcurl 进行 HTTP POST 请求以及解析响应数…

【含文档+源码】基于SpringBoot的过滤协同算法之网上服装商城设计与实现

项目介绍 本课程演示的是一款 基于SpringBoot的过滤协同算法之网上服装商城设计与实现,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含:项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署…

【PCB工艺】软件是如何控制硬件的发展过程

软件与硬件的关系密不可分,软件的需求不断推动硬件的发展,而硬件的进步又为软件创新提供了基础。 时光回溯到1854年,亨利戈培尔发明了电灯泡(1879年,托马斯阿尔瓦爱迪生找到了更合适的材料研制出白炽灯。)…

Electron 项目开机自启动

app.setLoginItemSettings 与 auto-launch 对比分析 一、稳定性对比 1. app.setLoginItemSettings 优点:作为Electron官方API,有官方维护和支持缺点: 在某些Windows版本上存在已知问题部分Windows 10/11更新后可能失效在macOS权限更严格的…

JS—异步编程:3分钟掌握异步编程

个人博客:haichenyi.com。感谢关注 一. 目录 一–目录二–引言三–JavaScript 事件循环机制四–定时器的秘密:setTimeout 和 setInterval五–异步编程模型对比 二. 引言 在现代Web开发中,异步编程是提升性能的关键技术。无论是脚本加载&am…