什么是优先队列
优先队列是队列的扩展,具有以下属性:
- 每个元素都有一个优先级。
- 元素具有与它们关联的优先级,并且具有最高优先级的元素始终在队列的前面。
- 如果两个元素具有相同的优先级,则它们按照它们在队列中出现的顺序进行排序。
- 优先队列的插入和删除操作具有O(log n)时间复杂度。
问题
我们想要实现一个队列,它能够以给定的优先级来对元素排序,且每次 pop 操作时都会返回优先级最高的那个元素。
解决方法
使用heapq模块进行解决
下面的这个例子是实现优先级队列
import heapq
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]
讨论
heapq是一个堆队列算法,它提供了堆的基本操作,如插入、弹出最小元素等。
这个程序定义了一个PriorityQueue类,它包含两个实例变量:_queue和_index。_queue是一个列表,用于存储元素和它们的优先级,而_index是一个计数器,用于为每个元素分配唯一的索引。这个计数器是在每次插入元素时递增的。
该程序实现了两个方法:push()和pop()。push()方法用于将元素插入队列中,它接受两个参数:item表示要插入的元素,priority表示该元素的优先级。在插入元素时,程序将元素、它的优先级和索引作为一个三元组添加到队列中。***为了实现优先级队列的逻辑,程序将优先级取负数,这样优先级越高的元素会被放在堆的顶部。***最后,程序递增索引以确保每个元素都有不同的优先级和顺序。
pop()方法用于弹出队列中的最高优先级元素,并返回该元素。在调用heapq.heappop()函数时,程序会从队列中弹出具有最高优先级的元素。这个元素是三元组,因此程序返回元组的最后一个元素,即原始的item值。
这个程序是一个简单但有效的优先队列实现,它使用了Python标准库中的堆算法。我们可以使用这个优先队列来实现各种算法,例如Dijkstra算法、A*算法等。