堆:完全二叉树,自上而下,自左向右添加元素,除了最后一层其他层全为满的,最后一层的节点都靠左对齐。每个节点k都有两个子节点2k+1,2k+2.
小根堆:每个节点小于等于子节点。
大根堆:每个节点大于等于子节点。
python内置库:import heapq
定义一个数组a=list(map(int,input().split()))
1.将数组a转化为堆(默认为小根堆,如果想变为大根堆那么把元素全加一个负号。)
heapq.heapify(a)
2.最小堆a中添加元素x
heapq.heappush(a,x)
3.弹出并返回最小元素
heapq.heappop(a)
4.弹出并返回最小元素同时添加x
heapq.heapreplace(a,x)
优先队列:
一种抽象的数据类型,依照其它的数据结构来实现对的,非严格说优先队列就是堆,python中优先队列底层依照堆来实现,即对堆进行了封装。
from queue import PriorityQueue
pd=PriorityQueue() ,(不能将pd转化为list,报错)
pd.put(x) 向优先队列pd中添加元素x,x可以是二维元组。相当于堆中的(heapq.heappush(a,x))
pd.get()取出优先队列中最小的元素(取出优先队列中优先级最高的元素,默认为小根堆,如果想变为大根堆则变为相应的负数)相当于堆中的heapq.heappop(a)
pd.queue[0]获取优先队列中的最小元素(不删除)