问题:怎样实现一个按优先级排序的队列?并且在这个队列上面每次pop操作总是返回优先级最高的那个元素
解决方案:
下面的类利用heapq模块实现了一个简单的优先级队列:
- # 此为排序序列
- import heapq
- class PriorityQueue:
- def __init__(self):
- self._queue = []
- self._index = 0
-
- def push(self, item, priority):
- # heapq.heappush 将字符按照优先级从高到低插入self.queue列表里
- heapq.heappush(self._queue, (-priority, self._index, item))
- # 此处的优先级比较方法为先按照元组里第一个元素进行比较,然后再根据第二个元素进行比较,依次类推(此处先比较优先级,在比较插入顺序,在比较字符的大小)
- self._index += 1
- def pop(self):
- # heapq.heappop 弹出并返回最小值
- return heapq.heappop(self._queue)[-1]
- # 此处的负一目的是只打印最后的字符,否则打印出来的为(5, 1, Item('bar'))
- # 更改字符格式
- class Item:
- def __init__(self, name):
- self.name = name
- def __repr__(self):
- return 'Item({!r})'.format(self.name)
-
下面是它的使用方式:
- q = PriorityQueue()
- q.push(Item('foo'), 1)
- q.push(Item('bar'), 5)
- q.push(Item('spam'), 4)
- q.push(Item('grok'), 1)
-
- q.pop()
- # Item('bar') 因为bar的优先级最高为5
- q.pop()
- # Item('spam')
- q.pop()
- # Item('foo') 当优先级一样时按插入顺序进行输出
- q.pop()
- # Item('grok')