【LeetCode 刷题】栈与队列-队列的应用

此博客为《代码随想录》栈与队列章节的学习笔记,主要内容为队列的应用相关的题目解析。

文章目录

  • [239. 滑动窗口最大值](#239. 滑动窗口最大值)
  • [347. 前 K 个高频元素](#347. 前 K 个高频元素)

239. 滑动窗口最大值

题目链接

python 复制代码
class Solution:
    def maxSlidingWindow(self, nums: List[int], k: int) -> List[int]:
        q = []
        # 未形成窗口
        for i in range(k):
            while q and q[-1] < nums[i]:
                q.pop()
            q.append(nums[i])
        res = [q[0]]
        # 形成窗口
        for i in range(len(nums) - k):
            # 出窗口
            if q[0] == nums[i]:
                q.pop(0)
            # 入窗口
            while q and q[-1] < nums[i + k]:
                q.pop()
            q.append(nums[i + k])
            res.append(q[0])
        return res
  • 使用非严格递减 单调队列
    • num 入窗口时,需要将队列中所有 < num 的元素弹出(注意不是 <=),再将 num 入队列
    • num 出窗口时,如果和队列头部相等,则队列头部也弹出

(图片源自 Krahets 的题解

347. 前 K 个高频元素

题目链接

python 复制代码
class Solution:
    def topKFrequent(self, nums: List[int], k: int) -> List[int]:
        count = Counter(nums)
        heap = []
        for key, val in count.items():
            if len(heap) >= k:
                if val > heap[0][0]:
                    heapq.heapreplace(heap, (val, key))
            else:
                heapq.heappush(heap, (val, key))
        return [item[1] for item in heap]
  • 使用优先级队列(最小堆):题目要求的是前 k 个高频元素,通过维护大小为 k 的最小堆,把已经不在前 k 频率的元素(堆顶元素)弹出,最终堆中只剩下前 k 个高频元素,时间复杂度 O ( n log ⁡ k ) O(n\log k) O(nlogk)
  • Python 的 heapq 模块提供了一组操作,用于管理一个最小堆的数据结构:
    • heapq.heappush():将一个元素插入到堆中,同时维护堆的特性
    • heapq.heapreplace():将堆顶元素替换为一个新的元素,同时维护堆的特性
  • 进入堆中的为元组,第一个元素为频率,第二个元素为对应的数字:由于 Python 比较元组时,Python 会从第一个元素开始逐个比较,因此会先比较频率,从而间接将频率作为优先级队列的比较关键字
  • 注:for 循环的变量不能写 k, v,会和函数参数 k 冲突
相关推荐
Swizard6 分钟前
拒绝“狗熊掰棒子”!用 EWC (Elastic Weight Consolidation) 彻底终结 AI 的灾难性遗忘
python·算法·ai·训练
Spider赵毅8 分钟前
python实战 | 如何使用海外代理IP抓取Amazon黑五数据
python·tcp/ip·php
月光技术杂谈14 分钟前
基于Python的网络性能分析实践:从Ping原理到自动化监控
网络·python·性能分析·ping·时延·自动化监控
龘龍龙17 分钟前
Python基础学习(四)
开发语言·python·学习
Trouvaille ~33 分钟前
【C++篇】把混沌映射成秩序:哈希表的底层哲学与实现之道
数据结构·c++·stl·哈希算法·散列表·面向对象·基础入门
Yeats_Liao1 小时前
MindSpore开发之路(四):核心数据结构Tensor
数据结构·人工智能·机器学习
洵有兮1 小时前
python第四次作业
开发语言·python
kkoral1 小时前
单机docker部署的redis sentinel,使用python调用redis,报错
redis·python·docker·sentinel
fab 在逃TDPIE1 小时前
Sentaurus TCAD 仿真教程(十)
算法
BoBoZz191 小时前
IterativeClosestPoints icp配准矩阵
python·vtk·图形渲染·图形处理