最大堆 的 python 实现

数组存储数据 ,数组0元素位置设置哨兵,为sys.maxsize最大整数。
python3的整数除法为 //

>>> 5//2
2
import sys

class MaxHeap:

    def __init__(self, size):
        self._size = size
        self._max_heap = [sys.maxsize]



    def isFull(self):
        """"""
        return self._size + 1 == len(self._max_heap)    #0的位置不存储


    def insert(self, item):
        """"""
        if self.isFull():
            print("最大堆满了")
            return
        self._max_heap.append(item)
        i = len(self._max_heap) - 1
        while (self._max_heap[i//2] < item):
            self._max_heap[i] = self._max_heap[i // 2]
            i = i // 2
        self._max_heap[i] = item


    def isEmpty(self, max_heap):
        return len(self._max_heap) == 1


    def deleteElement(self):
        if self.isEmpty():
            print("最大堆是空的")
        maxItem = self._max_heap[1]

        temp = self._max_heap[len(self._max_heap) - 1]
        parent = 1
        while(parent*2 <= len(self._max_heap)-1):
            child = parent*2
            if child!= len(self._max_heap)-1 & self._max_heap[child] < self._max_heap[child+1]:
                child += 1
            if temp > self._max_heap[child]:
                break
            else:
                self._max_heap[parent] = self._max_heap[child]
            parent = child
        return maxItem


if __name__ == '__main__':
    max_heap = MaxHeap(4)
    max_heap.insert(222)
    max_heap.insert(32)
    max_heap.insert(3)
    max_heap.insert(6)
    print(max_heap._max_heap)
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值