Python-heapq堆

2023-11-15

1.堆介绍

  • 堆是非线性的树形的数据结构,有两种堆,最大堆与最小堆。( heapq库中的堆默认是最小堆)。
    最大堆,树种各个父节点的值总是大于或等于任何一个子节点的值。
    最小堆,树种各个父节点的值总是小于或等于任何一个子节点的值。
    在这里插入图片描述
  • 我们一般使用二叉堆来实现优先级队列,它的内部调整算法复杂度为logN。堆是一个二叉树,其中最小堆每个父节点的值都小于或等于其所有子节点的值。整个最小堆的最小元素总是位于二叉树的根节点。
  • python的heapq模块提供了对堆的支持。 heapq堆数据结构最重要的特征是heap[0]永远是最小的元素。

2.堆的基本技巧

  • 常用方法:nlargest(),nsmallest(),heapify(),heappop();
  • 如果需要的个数较小,使用nlargest或者nsmallest比较好;
  • 如果需要的个数已经接近了序列长度,使用sorted()[:N]获取前N个数据比较好;
  • 如果只需要唯一一个最大或最小值,则直接使用max()或者min()。

3.heapq堆的常用方法

  • heapq.heappush(heap, item)
    heap为定义堆,item增加的元素。
  • heapq.heapify(list)
    将列表转换为堆。
  • heapq.heappop(heap)
    删除并返回最小值,因为堆的特征是heap[0]永远是最小的元素,所以一般都是删除第一个元素。
  • heapq.heapreplace(heap.item)
    删除并返回最小元素值,添加新的元素值。
  • heapq.heappushpop(list, item)
    判断添加元素值与堆的第一个元素值对比;如果大,则删除并返回第一个元素,然后添加新元素值item.如果小,则返回item. 原堆不变。
  • heapq.merge(a1, a2, …)
    将多个堆合并。
  • heapq.nlargest(n, heap_name)
    查询堆中最大的n个元素。
  • heapq.nsmallest(n, heap_name)
    查询堆中最小的n个元素。
  • 使用heapq编写优先级队列
    class PriorityQueue:
        def __init__(self):
            self.__queue = []
            self.__index = 0
            
        def push(self, item, priority):
            heapq.heappush(self.__queue, (-priority, self.__index, item))
            # 第一个参数:添加进的目标序列
            # 第二个参数:将一个元组作为整体添加进序列,目的是为了方便比较
            # 在priority相等的情况下,比较_index
            # priority为负数使得添加时按照优先级从大到小排序,因为堆排序的序列的第一个元素永远是最小的
            self.__index += 1
            
        def pop(self):
            # 返回按照-priority 和 _index 排序后的第一个元素(是一个元组)的最后一个元素(item)
            return heapq.heappop(self.__queue)[-1]
    
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Python-heapq堆 的相关文章

随机推荐

  • binlog_do_db 与 binlog_ignore_db

    前言 经过前面文章学习 我们知道 binlog 会记录数据库所有执行的 DDL 和 DML 语句 除了数据查询语句select show等 注意默认情况下会记录所有库的操作 那么如果我们有另类需求 比如说只让某个库记录 binglog 或排
  • [羊城杯 2020]A Piece Of Java

    羊城杯 2020 A Piece Of Java 文章目录 羊城杯 2020 A Piece Of Java 源码分析 从后往前测试 逐步写exp 构造DatabaseInfo类对象 InfoInvocationHandler 动态代理 序
  • 树莓派配置motion获取实时视频流

    一 串口连接CSI摄像头模块 二 升级安装程序apt get 输入以下命令 sudo apt get update sudo apt get upgrade 三 激活树莓派摄像头模块 输入sudo raspi config 选择Interf
  • Android透明状态栏和导航栏方案最终版

    前言 仔细留意常用App 就会发现有些 App 的状态栏和导航栏有透明效果 或者是沉浸式效果 比如QQ音乐客户端 是像这个样子的 我们看到整个页面顶部与导航栏浑然一体 在看导航栏 虽然我们打开了手机导航栏 但是整个页面 还是延伸到了导航栏底
  • 避免 PageHelper 使用中的一些坑

    多年不用PageHelper了 最近新入职的公司 采用了此工具集成的框架 作为一个独立紧急项目开发的基础 项目开发起来 还是手到擒来的 但是没想到 最终测试的时候 深深的给我上了一课 我的项目发生了哪些奇葩现象 一切的问题都要从我接受的项目
  • C++ PRIMER PLUS 第六版编程答案(二)

    2 7编程练习 1 编写一个小程序 要求用户使用一个整数指出自己的身高 单位为英寸 然后将身高转换为英尺和英寸 该程序使用下划线字符来指示输入位置 另外 使用一个const符号常量来表示转换因子 include
  • 解决eclipse中启动Tomcat成功但是访问不了Tomcat问题

    自己搭建了一个springMVC项目 中间出了一些问题 在排查问题的过程中发现eclipse成功启动了Tomcat 但是在浏览器中输入localhost 8080却给我一个冷冷的404 我以为是Tomcat出问题了 心情大好 以为自己搭建的
  • Github copilot几个使用技巧,自动补全代码

    上一篇文章介绍了如何在vscode 中引入 Github Copilot 这一张我们介绍一下Github Copilot 的使用技巧 一 常用快捷键 快捷键 含义 tab 应用提示代码 esc 拒绝提示代码 ctrl enter 打开提示面
  • Caused by: java.lang.UnsupportedOperationException 解决方案

    b 背景 b 今天在跑一个UnitTest 跑的过程中想在list的最后多加一个Element 即 List add Element e 多测试一条数据 可是在run的过程中 却一直在抛 Caused by java lang Unsupp
  • V-REP安装

    小知识 是当前目录 是父级目录 是根目录 1 下载V REP 官网地址 http www v rep eu downloads html 我用ubuntu16 04下载V REP PRO EDU V3 5 0 Linux tar 2 解压安
  • STM32通用定时器输出PWM控制舵机 —— 重装载值、比较值、当前值

    参考 stm32 定时器输出PWM原理及工作原理 控制舵机 作者 点灯小哥 发布时间 2021 03 09 23 17 52 网址 https blog csdn net weixin 46016743 article details 11
  • 【数理统计】双因素方差分析

    下面用SPSS搞一下 这一步选择模型 要不要考虑交叉因素 根据实际情况 我先不选交叉因素 选主效应 在这里可以看到随机误差项的自由度为0 不满足方差齐性 这是为什么呢 这是因为SPSS的自由度和上述经典算法是不一致的 SPSS中是怎么算的呢
  • python自动化课程笔记(十二)闭包、装饰器

    闭包 闭包就是能够读取其他函数内部变量的函数 例如在javascript中 只有函数内部的子函数才能读取局部变量 所以闭包可以理解成 定义在一个函数内部的函数 在本质上 闭包是将函数内部和函数外部连接起来的桥梁 闭包 def test nu
  • 【专题5: 硬件设计】之 【66.开关电源 之 buck电路和引入电感】

    嵌入式工程师成长之路 系列文章 总目录 系列文章总目录 希望本是无所谓有 无所谓无的 这正如脚下的路 其实地上本没有路 走的人多了 也便成了路 原创不易 文章会持续更新 欢迎微信扫码关注公众号 承接 小程序 嵌入式 PC端项目开发 联系作者
  • Kubernetes tutorial - K8S 官方入门教程

    tutorials 教程 kubectl 的命令手册 1 Creating a Cluster 1 1 Using Minikube to Create a Cluster Kubernetes Clusters Kubernetes co
  • 51单片机总结【引脚、时钟电路、复位电路、I/O端口、内部结构】

    1 功能简述 STC89C52 是一种低功耗 高性能CMOS8位微控制器 具有8K在系统可编程Flash存储器 ROM STC89C52具有以下标准功能 8k字节Flash 程序存储器ROM 512字节RAM 256字节内部和256字节外部
  • 解决Linux系统字符集不匹配安装软件失败问题

    使用SSHSecureShellClient客户端连接Linux服务器 把字符集设置为 export LC CTYPE zh CN GB18030 export LC ALL zh CN GB18030 export LANG zh CN
  • 面试官:熔断和降级有什么区别?

    熔断和降级都是系统自我保护的一种机制 但二者又有所不同 它们的区别主要体现在以下几点 概念不同 触发条件不同 归属关系不同 1 概念不同 1 1 熔断概念 熔断 一词早期来自股票市场 熔断 Circuit Breaker 也叫自动停盘机制
  • 1. Netty核心功能与线程模型详解

    Netty 1 认识Netty 2 第一个Netty程序 3 Netty组件 3 1 EventLoop和EventLoopGroup Channel ChannelPipeline和ChannelHandlerContext Channe
  • Python-heapq堆

    1 堆介绍 堆是非线性的树形的数据结构 有两种堆 最大堆与最小堆 heapq库中的堆默认是最小堆 最大堆 树种各个父节点的值总是大于或等于任何一个子节点的值 最小堆 树种各个父节点的值总是小于或等于任何一个子节点的值 我们一般使用二叉堆来实