使用Python实现优先级队列(堆)--以最大堆为例

思路:
使用list实现

优先级队列的特点就是
1.父节点总是比子节点要大
2.是一种完全二叉树

按照以上特点
1.可以得到父节点的两个子节点的index
2.通过简单的对比大小,交换list中元素的位置,最后得到重新排序的新列表

class Pq(object):
    def __init__(self, arr):
        self.arr = arr#  接受一个列表
        self.index = 0
        self.flag = 1
        while self.flag == 1:
            self.build_q()


    def build_q(self):
        self.flag = 0#  先置0,如果下面经过swap,则在swap函数中又会变为1
        for index in range(len(self.arr)): #  遍历以所有节点为head的三角形最小树
            h = index
            l = index*2 + 1
            r = index*2 + 2#  根据优先级队列的原理,父节点与的两个子节点的index
            if r <= len(self.arr)-1:#  目前节点有两个孩子
                self.shift_up(h, l, r) 
            elif l == len(self.arr)-1:#  目前节点只有左孩子
                if self.arr[h] < self.arr[l]:
                    self.swap(h, l)
            elif l > len(self.arr)-1:#  目前节点已经没有子节点
                continue

    def shift_up(self, head, left, right):#  接受三个元素的列表
        if self.arr[head] < self.arr[left]:
            self.swap(head, left)
        if self.arr[head] < self.arr[right]:
            self.swap(head, right)
    
    def swap(self, index1, index2):#  交换一个列表中,对应下标的两个元素的位置
        self.flag = 1#  交换过就表示形成的树不是最终形态
        temp = self.arr[index1]
        self.arr[index1] = self.arr[index2]
        self.arr[index2] = temp
        
    def incert(self, val):
        self.arr.append(val)
        index = len(self.arr)-1#  最末元素的index
        h_index = 1#  初始化一个h_index,代表插入节点的父节点的index,大于0进入while即可
        while h_index != 0:
            if index % 2 == 0:#  如果,能被2整除,说明是挂在右边,如果不能则是左边
                h_index = (index-1)//2
            else:#  挂在左边
                h_index = index//2
            if self.arr[h_index] < self.arr[index]:
                self.swap(h_index, index)
                index = h_index
    
    def pop(self):
        self.arr[0] = self.arr[-1]
        self.arr.pop()
        self.flag = 1
        while self.flag == 1:
            self.build_q()
        
        
    def show(self):
        print(self.arr)


q = Pq([1,1,2,2,3,3,4])
q.show()
q.incert(5)
q.show()
q.pop()
q.show()


>>>[4, 2, 3, 1, 2, 1, 3]
>>>[5, 4, 3, 2, 2, 1, 3, 1]
>>>[4, 2, 3, 1, 2, 1, 3]

本例程到目前只实现了实现优先级队列的基本功能。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值