亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python實現一個優先級隊列的方法

瀏覽:7日期:2022-07-15 16:20:32

問題

怎樣實現一個按優先級排序的隊列? 并且在這個隊列上面每次 pop 操作總是返回優先級最高的那個元素

解決方案

下面的類利用 heapq 模塊實現了一個簡單的優先級隊列:

import heapqclass 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]

下面是它的使用方式:

>>> 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’)>>> q.pop()Item(’spam’)>>> q.pop()Item(’foo’)>>> q.pop()Item(’grok’)>>>

仔細觀察可以發現,第一個 pop() 操作返回優先級最高的元素。 另外注意到如果兩個有著相同優先級的元素( foo 和 grok ),pop 操作按照它們被插入到隊列的順序返回的。

討論

這一小節我們主要關注 heapq 模塊的使用。 函數 heapq.heappush() 和 heapq.heappop() 分別在隊列 _queue 上插入和刪除第一個元素, 并且隊列 _queue 保證第一個元素擁有最高優先級( 1.4 節已經討論過這個問題)。 heappop() 函數總是返回”最小的”的元素,這就是保證隊列pop操作返回正確元素的關鍵。 另外,由于 push 和 pop 操作時間復雜度為 O(log N),其中 N 是堆的大小,因此就算是 N 很大的時候它們運行速度也依舊很快。

在上面代碼中,隊列包含了一個 (-priority, index, item) 的元組。 優先級為負數的目的是使得元素按照優先級從高到低排序。 這個跟普通的按優先級從低到高排序的堆排序恰巧相反。

index 變量的作用是保證同等優先級元素的正確排序。 通過保存一個不斷增加的 index 下標變量,可以確保元素按照它們插入的順序排序。 而且, index 變量也在相同優先級元素比較的時候起到重要作用。

為了闡明這些,先假定 Item 實例是不支持排序的:

>>> a = Item(’foo’)>>> b = Item(’bar’)>>> a < bTraceback (most recent call last):File '<stdin>', line 1, in <module>TypeError: unorderable types: Item() < Item()>>>

如果你使用元組 (priority, item) ,只要兩個元素的優先級不同就能比較。 但是如果兩個元素優先級一樣的話,那么比較操作就會跟之前一樣出錯:

>>> a = (1, Item(’foo’))>>> b = (5, Item(’bar’))>>> a < bTrue>>> c = (1, Item(’grok’))>>> a < cTraceback (most recent call last):File '<stdin>', line 1, in <module>TypeError: unorderable types: Item() < Item()>>>

通過引入另外的 index 變量組成三元組 (priority, index, item) ,就能很好的避免上面的錯誤, 因為不可能有兩個元素有相同的 index 值。Python 在做元組比較時候,如果前面的比較已經可以確定結果了, 后面的比較操作就不會發生了:

>>> a = (1, 0, Item(’foo’))>>> b = (5, 1, Item(’bar’))>>> c = (1, 2, Item(’grok’))>>> a < bTrue>>> a < cTrue>>>

如果你想在多個線程中使用同一個隊列,那么你需要增加適當的鎖和信號量機制。 可以查看 12.3 小節的例子演示是怎樣做的。

heapq 模塊的官方文檔有更詳細的例子程序以及對于堆理論及其實現的詳細說明。

以上就是Python實現一個優先級隊列的方法的詳細內容,更多關于Python實現優先級隊列的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲精品国产男人的天堂 | 免费视频爰爱太爽了 | 国产婷婷色一区二区三区深爱网 | 天天黄色片 | 在线视频国产一区 | 初女破苞国语在线观看免费 | 大人和孩做爰h视频在线观看 | 99久久国产综合精品2020 | 中文精品久久久久国产网址 | 国产精品女主播自在线拍 | 全免费毛片在线播放 | 日韩中文字幕推理片 | 成年黄色片 | 欧美精品一区二区三区在线播放 | 一区二区色 | 一级黄色激情片 | 亚洲国产综合专区在线播一一 | 4438成人成人高清视频 | 91看片淫黄大片欧美看国产片 | 一级特黄毛片 | 婷婷在线五月 | 日本高清在线精品一区二区三区 | 国产精品亚洲玖玖玖在线靠爱 | 国产一级爱片 | 婷婷丁香五月中文字幕 | 免费看一级欧美毛片视频 | 天天影视色香欲综合网网站麻豆 | 婷婷在线播放 | 亚洲欧美精品在线 | 男女自偷自拍视频免费观看篇 | 97色伦图片97综合影院久久 | 欧美中文一区 | 精品一久久香蕉国产线看观看下 | 自由xxx色视频18 | 鸥美黄色片 | 国产高清在线观看视频 | 亚洲日韩精品欧美一区二区一 | 国产精品久久久福利 | 免费中文字幕不卡视频 | xzl仙踪林一区 | 黄色一级大片网站 |