Python 堆 Heap 解决第K大(小)问题

1.Python中Heap是基于列表list实现的。

2.Python中Heap有标准的库函数,直接import heapq 即可

3.Python中Heap默认为最小堆 min_heap,也就是堆顶元素始终是堆中最小的元素。

3.heapify可以在线性O(n)的时间复杂度内将输入的列表转化为堆,用于创建一个堆。

list=heapify(list) #这时候list数组,就已经是按堆结构放置的数组了。

4.nlargest、nsmallest求解列表中(此列表不一定按照堆的方式排列)前K大的元素和前K小的元素,返回的是一个列表,包含前K大(K小)元素的列表。

items=heapq.nlargest(k, list) 

5.heappush和heappop方法,压入和弹出方法,但在push或者pop之后,仍保持是一个堆栈。

heapq.heappush(list,val) # 将数值 val 插入堆中,插入之后,仍保持最大(最小)堆结构

6.heappushpop方法,先push,再pop,实现了在保持堆中数量不变的同时更新了堆。

heapq.heappushpop(list,val) # 先将数值val插入堆中,插入之后最大(最小)堆结构进行调整,但仍保持堆,再将新堆的堆顶元素弹出,list是按照堆结构来放置的数组

 

LeetCode 703. 数据流中的第K大元素

import heapq
class KthLargest:
    def __init__(self, k: int, nums):
        self.pool = heapq.nlargest(k, nums)
        heapq.heapify(self.pool)
        self.k = k

    def add(self, val: int) -> int:
        if len(self.pool) < self.k:
            heapq.heappush(self.pool,val)
        else:
            heapq.heappushpop(self.pool,val)
        return self.pool[0]

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值