码迷,mamicode.com
首页 > 编程语言 > 详细

飘逸的python - 实现一个极简的优先队列

时间:2014-10-14 15:05:08      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:python   优先队列   最小堆   

一个队列至少满足2个方法,put和get.

借助最小堆来实现.

这里按"值越大优先级越高"的顺序.

#coding=utf-8
from heapq import heappush, heappop
class PriorityQueue:
    def __init__(self):
        self._queue = []

    def put(self, item, priority):
        heappush(self._queue, (-priority, item))

    def get(self):
        return heappop(self._queue)[-1]

q = PriorityQueue()
q.put('world', 1)
q.put('hello', 2)
print q.get()
print q.get()


飘逸的python - 实现一个极简的优先队列

标签:python   优先队列   最小堆   

原文地址:http://blog.csdn.net/handsomekang/article/details/40073581

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!