>[success] # 一些常用的heapq熟悉
>[danger] ##### heapify -- 将列表转换成堆
堆的重要特性就是第0个元素总是最小
~~~
import heapq
nums = [23,3,5,6,7,-1,5,6,1,10]
# 为了不破坏原来的list集合所以特意重新转换一下
heap = list(nums)
heapq.heapify(heap)
print(heap)
打印结果:
[-1, 1, 5, 3, 7, 5, 23, 6, 6, 10]
~~~
>[danger] ##### heappop -- 删除最小值
这个 运行速度O(logN)也就是堆越大,使用此方法的运行速度越慢
~~~
import heapq
nums = [23,3,5,6,7,-1,5,6,1,10]
heap = list(nums)
# 先转换成堆然后再删除
heapq.heapify(heap)
# 删除第0个元素
print(heapq.heappop(heap))
打印结果:
-1
~~~
>[danger] ##### heapreplace -- 弹出最小值,然后将新参数加入
只弹出未添加时最小值,下面的例子当加入的是-3,弹出的是-1
~~~
import heapq
nums = [23,3,5,6,7,-1,5,6,1,10]
heap = list(nums)
# 先转换成堆然后再删除
heapq.heapify(heap)
heapq.heapreplace(heap,66)
print(heap)
打印结果:
[1, 3, 5, 6, 7, 5, 23, 6, 66, 10]
~~~
>[danger] ##### heappushpop -- 弹出最小值,然后将新参数加入
只弹出添加后最小值,下面的例子当加入的是-3,弹出的是-3
~~~
import heapq
nums = [23,3,5,6,7,-1,5,6,1,10]
heap = list(nums)
# 先转换成堆然后再删除
heapq.heapify(heap)
heapq.heappushpop(heap,66)
print(heap)
打印结果:
[1, 3, 5, 6, 7, 5, 23, 6, 66, 10]
~~~
>[danger] ##### heappush 添加元素
~~~
import heapq
nums = [23,3,5,6,7,-1,5,6,1,10]
heap = list(nums)
# 先转换成堆然后再删除
heapq.heapify(heap)
heapq.heappush(heap,66)
print(heap)
~~~
>[success] # 实现优先级案例
~~~
1. 要有能储存的堆,也就是列表类型
2. 要设置优先级
3. 要设置插入的顺序
~~~
>[danger] ##### 案例
>实现一个队列,能够根据优先级来对元素排序,每次返回优先级最高的
* self._queue 因为heappush的第一个参数给是个列表
* 后面元组的参数依次 优先级,插入的序号,和插入的内容
~~~
class PriorityQueue:
def __init__(self):
self._queue = []
self._index = 0
def push(self,item,priority):
heapq.heappush(self._queue,(-priority,self._index,item))
self._index += 1
def pop(self):
return heapq.heappop(self._queue)[-1]
~~~
* 实现效果
当优先级一样的时候,先返回,优先插入的
~~~
class Item:
def __init__(self,name):
self.name = name
def __repr__(self):
return self.name
q = PriorityQueue()
q.push(Item('foo'),1)
q.push(Item('fss'),2)
q.push(Item('aaa'),1)
print(q.pop())
print(q.pop())
print(q.pop())
打印结果:
fss
foo
aaa
~~~
- PYTHON-- 基础
- Python -- 变量、常量、注解
- 算数\比较\赋值\逻辑运算符
- Python -- input 控制台用户输入
- Python -- 流程控制/循环语句
- Python -- 切片
- Python -- 数据类型
- 基础数据类型
- int -- 数字类型
- str -- 字符类型
- bool -- 布尔类型
- list -- 列表
- type -- 元祖
- dict -- 字典
- set -- 集合
- Python -- 深浅copy
- Python -- 文件的读写
- Python -- 函数
- 函数 -- 做参数使用
- 函数 -- 闭包
- 函数 -- 生成器
- 函数 -- 列表推导式
- 案例
- 基础案例一
- 基础案例二
- 基础案例三
- COOKBOOK
- LIST、STR、DICT、TUPLE
- LIST - 列表方法总结
- 一、序列拆分成单独变量
- 二、* 妙用
- 三、deque- 双向队列
- 四、求找到最大或最小的N个元素
- 4.1 heapq-- 简单使用
- 五、去重并保持列表顺序不变
- 六、切片slice
- 七、counter 统计序列中元素次数
- 八、itemgetter 列表套着字典排序
- 九、处理大量的列表数据
- 十、随机事件处理列表
- DICT - 字典的总结方法
- 一、defaultdict 解决 KeyError
- 二、OrdereDict有序字典
- 三、zip 和 max/min 比较
- IDCT和LIST- 推导式
- 一、LIST 推导式
- 二、字典推到式
- TUPLE-元组
- 一、命名元组
- STR-字符串
- 一、常见的字符串方法
- 二、字符串拆分
- 三、字符串的位置匹配
- 四、字符串替换
- 五、正则大小写/换行匹配
- 六、对字节类型处理
- 数字、日期、时间处理
- 一、数字的处理
- 二、时间换算
- 2.1 时间运算
- 2.2计算某一时刻上周几的日期
- 2.2对时间转换格式优化
- 迭代器和生成器
- 一、iter 迭代器 使用案例
- 二、生成器 yeild
- 三、构建一个反向迭代方法
- 四、实现反正函数构造
- 五、迭代对象切片/跳过元素
- 六、迭代出所有的组合排列
- 七、索引-值迭代序列化
- 八、zip 同时迭代多个序列
- 九、同时循环多个可迭代对象
- 十、yield from 递归案例
- 十一、合并序列,并按顺序输出
- 十二、使用 iter 替代 while True
- 操作文件
- 一、处理文件路径
- 二、检测文件/获取文件信息
- 函数
- 一、函数基本案例使用
- 二、匿名函数
- 三、回调函数
- 四、闭包实现一个单个方法类
- 五、函数嵌套回调函数
- 类与对象
- 一、str/repr--让类字符串表示
- 二、format -- 格式化类的内容
- 三、with -- 上下文管理类
- 四、创建节省内存的类
- 五、将类里面方法变成属性
- 六、调用父类方法
- 七、扩展子类中的属性
- 八、创建新的类或者实类属性
- 九、简化数据结果,简化init
- 十、python 接口写法
- 十一、通过类属性创建委托访问
- 十二、__new__重新初始化init
- 十三、通过字符串调用类
- 元编程
- 一、装饰器
- 1.1 去掉装饰器修饰
- 1.2 可接受参数装饰器
- 1.3利用装饰器对函数参数类型检查
- 1.4编写类装饰器
- 1.5为类方法和静态方法加装饰器
- 1.6通过装饰器给装饰函数加参数
- 线程和进程