国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python heapq使用詳解及實例代碼

2019-11-25 16:22:57
字體:
供稿:網(wǎng)友

 Python heapq 詳解

Python有一個內(nèi)置的模塊,heapq標準的封裝了最小堆的算法實現(xiàn)。下面看兩個不錯的應(yīng)用。

小頂堆(求TopK大)

話說需求是這樣的: 定長的序列,求出TopK大的數(shù)據(jù)。

import heapqimport randomclass TopkHeap(object):  def __init__(self, k):    self.k = k    self.data = []  def Push(self, elem):    if len(self.data) < self.k:      heapq.heappush(self.data, elem)    else:      topk_small = self.data[0]      if elem > topk_small:        heapq.heapreplace(self.data, elem)  def TopK(self):    return [x for x in reversed([heapq.heappop(self.data) for x in xrange(len(self.data))])]if __name__ == "__main__":  print "Hello"  list_rand = random.sample(xrange(1000000), 100)  th = TopkHeap(3)  for i in list_rand:    th.Push(i)  print th.TopK()  print sorted(list_rand, reverse=True)[0:3]

大頂堆(求BtmK小)

這次的需求變得更加的困難了:給出N長的序列,求出BtmK小的元素,即使用大頂堆。

算法實現(xiàn)的核心思路是:將push(e)改為push(-e)、pop(e)改為-pop(e)。

class BtmkHeap(object):  def __init__(self, k):    self.k = k    self.data = []  def Push(self, elem):    # Reverse elem to convert to max-heap    elem = -elem    # Using heap algorighem    if len(self.data) < self.k:      heapq.heappush(self.data, elem)    else:      topk_small = self.data[0]      if elem > topk_small:        heapq.heapreplace(self.data, elem)  def BtmK(self):    return sorted([-x for x in self.data])

 感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 宜君县| 凉山| 奉新县| 澄城县| 桐梓县| 通辽市| 荥经县| 茌平县| 临朐县| 蕲春县| 巴青县| 三原县| 安龙县| 高碑店市| 全州县| 虎林市| 溧阳市| 呈贡县| 文山县| 临沭县| 无棣县| 泽州县| 余庆县| 通河县| 松江区| 新兴县| 来安县| 田林县| 札达县| 佳木斯市| 白朗县| 油尖旺区| 鄂伦春自治旗| 西乡县| 贵德县| 鄄城县| 桃园市| 武鸣县| 雅安市| 永寿县| 山阳县|