python使用Queue实现优先级队列
发布时间:2020-05-24 23:33:29 所属栏目:Python 来源:互联网
导读:python使用Queue实现优先级队列
|
下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。 脚本之家小编现在分享给大家,也给大家做个参考。 import Queue
class PriorityQueue(Queue.Queue):
def _put(self,item):
data,priority = item
self._insort_right((priority,data))
def _get(self):
return self.queue.pop(0)[1]
def _insort_right(self,x):
"""Insert item x in list,and keep it sorted assuming a is sorted.
If x is already in list,insert it to the right of the rightmost x.
"""
a = self.queue
lo = 0
hi = len(a)
while lo < hi:
mid = (lo+hi)/2
if x[0] < a[mid][0]: hi = mid
else: lo = mid+1
a.insert(lo,x)
def test():
pq = PriorityQueue()
pq.put(('b',1))
pq.put(('a',1))
pq.put(('c',1))
pq.put(('z',0))
pq.put(('d',2))
while not pq.empty():
print pq.get(),test() # prints z b a c d
以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。 如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
