python實現最大堆與最小堆


轉載:https://blog.csdn.net/Fire_KAKA/article/details/78297016

class MaxHeap(object): # def __init__(self): #   self.data = []  # 創建堆 #   self.count = len(self.data)  # 元素數量 def __init__(self, arr): self.data = copy.copy(arr) self.count = len(self.data) i = self.count / 2 while i >= 1: self.shiftDown(i) i -= 1 def size(self): return self.count def isEmpty(self): return self.count == 0 def insert(self, item): # 插入元素入堆 self.data.append(item) self.count += 1 self.shiftup(self.count) def shiftup(self, count): # 將插入的元素放到合適位置,保持最大堆 while count > 1 and self.data[(count/2)-1] < self.data[count-1]: self.data[(count/2)-1], self.data[count-1] = self.data[count-1], self.data[(count/2)-1] count /= 2 def extractMax(self): # 出堆 if self.count > 0: ret = self.data[0] self.data[0], self.data[self.count-1] = self.data[self.count-1], self.data[0] self.data.pop() self.count -= 1 self.shiftDown(1) return ret def shiftDown(self, count): # 將堆的索引位置元素向下移動到合適位置,保持最大堆 while 2 * count <= self.count : # 證明有孩子 j = 2 * count if j + 1 <= self.count: # 證明有右孩子 if self.data[j] > self.data[j-1]: j += 1 if self.data[count-1] >= self.data[j-1]: # 堆的索引位置已經大於兩個孩子節點,不需要交換了 break self.data[count-1], self.data[j-1] = self.data[j-1], self.data[count-1] count = j
---------------------
作者:Fire_KAKA
來源:CSDN
原文:https://blog.csdn.net/Fire_KAKA/article/details/78297016
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM