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

LeetCode 堆的插入与删除题解

LeetCode 堆的插入与删除题解

题目描述

实现堆的插入和删除操作。

堆的插入与删除

插入操作

  1. 将新元素添加到数组末尾
  2. 向上调整(sift up)

删除操作

  1. 删除堆顶元素
  2. 将数组末尾元素移到堆顶
  3. 向下调整(sift down)

代码实现

import heapq class MinHeap: def __init__(self): self.heap = [] def push(self, val): heapq.heappush(self.heap, val) def pop(self): return heapq.heappop(self.heap) def top(self): return self.heap[0] if self.heap else None # 测试 def test_min_heap(): heap = MinHeap() heap.push(3) heap.push(1) heap.push(2) print(heap.pop()) # 输出:1 print(heap.top()) # 输出:2 if __name__ == "__main__": test_min_heap()

总结

堆的插入和删除操作是堆的基本操作,通过向上和向下调整来维护堆的性质。

http://www.cnnetsun.cn/news/2475894.html

相关文章:

  • NoFences:3分钟让你的Windows桌面从杂乱到井井有条
  • 3种创意组合:探索Pixelle-Video的插件化视频生成系统
  • 如何高效使用权威SAR舰船检测数据集:SSDD完整实战指南
  • 多市场利润空间收窄之后跨境卖家如何集中团队资源
  • Gomobile踩坑实录:从‘找不到NDK’到成功生成AAR,我总结了这份避坑指南
  • 端侧AI基础设施核心环节与代表企业全景解析
  • 嵌入式工业方案实战:基于瑞萨芯片的可靠性设计、异构计算与交钥匙交付
  • 保姆级教程:在小程序里给ECharts图表加上手指缩放(附地图roam配置)
  • 揭秘OBS智能跟拍:5分钟掌握直播自动对焦革命性技巧
  • PDFMathTranslate:三步实现学术论文完美翻译的终极解决方案
  • Camera Shakify:为Blender动画注入真实相机抖动效果的终极指南
  • 5G工业网关:智慧工厂柔性产线与AI质检的通信基石
  • 告别‘Remount失败’:一篇文章搞懂Android分区验证(Verity)与OverlayFS
  • 输入输出与运算符--人机交互的伊始
  • Altium Designer实战:用xSignals搞定DDR内存等长布线,告别时序烦恼
  • 2026前端开发资源大全:工具、文档、框架、学习路线与实战指南
  • 10分钟搭建Sunshine游戏串流:免费开源的家庭游戏共享方案
  • IPXWrapper终极指南:让经典Windows游戏在现代系统重获联机生命
  • 书匠策AI:你的毕业论文“外挂“到底有多能打?一篇科普让你彻底看懂
  • 智能歌词同步:从音乐听众到歌词大师的macOS进阶指南
  • Linux 下访问 Windows 共享目录的完整指南
  • 乐鑫ESP-Mesh-Lite无线自组网方案:从原理到大规模物联网部署实战
  • 企业级跨平台媒体资源管理:BiliTools架构设计与微服务实践
  • Sora 2原生渲染引擎如何接管DaVinci Resolve时间线?:4步实现AI生成视频无缝调色与剪辑闭环
  • UVM寄存器模型核心API行为全解析:从主值、镜像值到实战避坑指南
  • AI 进入 ERP 后,企业如何管得住?治理、安全与组织变革(AI+ERP系列-10)
  • 别只盯着S21!用ADS仿真LNA时,这3个容易被忽略的细节(稳定性、实际元件模型、噪声圆)才是成败关键
  • 别再只用匿名登录了!手把手教你为Mosquitto Broker配置用户密码,并用MQTTX安全连接
  • 材料模拟避坑指南:MS中BFDH分析生长面时,Distance参数到底怎么看?
  • LAV Filters终极实战指南:解码器架构深度解析与性能调优