news 2026/6/22 13:35:02

代码随想录算法训练营day 10-11:栈与队列,滑动窗口最大值,大小顶堆

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
代码随想录算法训练营day 10-11:栈与队列,滑动窗口最大值,大小顶堆

用**栈**解决“匹配,消除,计算”问题

这类题的共同点:当前状态,依赖于最近一次未处理完的状态

对应习题:20. 有效的括号,1047. 删除字符串中的所有相邻重复项,150. 逆波兰表达式求值

做这些题会有一种“消消乐”的感觉,当前元素和上一个元素如果满足某种条件,进行一次操作,循环往复,这种情况是栈的天然适配场景

用**设计结构**解决“区间,频率”问题

这类题的共同点:为“查询目标”定制数据结构

对应习题:239.滑动窗口最大值,347.前k个高频元素

这些题就体现了:队列比起一个“容器”,它更像一种“行为约束”,栈同理。

239.滑动窗口最大值

要做这题,首先要注意到一个关键事实:“当窗口内的某个元素的后续元素比它自身大时,这个元素就不可能成为最大值了”。

为什么呢?举个例子:假设窗口内元素为[ 4,3,2,5 ],窗口内的 4 ,3 ,2如果想成为最大值,需要等待比他们大的5滑出窗口,然而事实是,窗口向右滑动,4,3,2绝对比5先滑出窗口,所以在5进入窗口的那一刻,前三个元素已经不可能成为最大值

所以我们要做的是,维护一个非单增队列,储存可能成为当前窗口最大值的候选,队头是当前窗口最大值,窗口滑动后,若队头滑出窗口,队头出队即可,需要元素入队时,删除所有比该元素大的队尾元素,然后该元素进入队尾,由此来维护队列的“非单调递增性”,明白了这个单调队列的思想,剩下的操作就比较简单了。

347.前k个高频元素

这题可以用“”来做,即优先队列,堆的顶部永远是最大或最小值,所以,先用HashMap统计一遍频率,再把元素塞入堆,用大顶堆还是小顶堆呢?其实用小顶堆会更好,如果用大顶堆,那该堆需要维护所有的元素频率,再弹出顶部元素k次,得到topk,内存和时间都会有浪费。其实用容量为k的小顶堆即可,频率比堆顶大的元素就入堆,堆容量大于k就弹出顶部的最小频率,最后得到topk

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/17 17:45:24

Java数组的初始化与实例化:从概念到实战,拆解核心逻辑与避坑指南

Java数组的初始化与实例化:从概念到实战,拆解核心逻辑与避坑指南 在Java编程中,数组是最基础的引用数据类型之一,也是处理批量同类型数据的核心工具。但很多开发者(尤其是初学者)常混淆「初始化」和「实例化…

作者头像 李华
网站建设 2026/6/21 11:01:41

学生选课信息管理系统

学生信息管理 目录 基于springboot vue学生信息管理系统 一、前言 二、系统功能演示 详细视频演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取: 基于springboot vue学生选课信息管理系统 一、…

作者头像 李华
网站建设 2026/6/20 20:42:13

基于Android的居家养老管理系统(源码+lw+部署文档+讲解等)

课题介绍 本课题聚焦居家养老服务响应慢、老人状态监测不及时、家属监管不便的痛点,设计实现基于 Android 的居家养老管理系统。系统以 Java 为核心开发语言,基于 Android 原生框架搭建移动端应用,搭配后端云服务架构,处理老人健康…

作者头像 李华
网站建设 2026/6/22 11:57:56

LobeChat能否撰写商业计划书?创业者的秘密武器

LobeChat能否撰写商业计划书?创业者的秘密武器 在今天这个快节奏的创业环境中,一份逻辑清晰、数据扎实、结构完整的商业计划书,往往是决定项目能否获得投资的关键。然而现实是,大多数创业者既不是专业写手,也没有专职的…

作者头像 李华
网站建设 2026/6/12 13:17:24

中小企业备份方案: 如何评估备份方案是否符合企业实际需求

成本、安全性与法规合规性这三方面考量,构成了评估备份解决方案是否符合企业实际需求的基础框架。业务需求评估评估备份解决方案时,必须首先审视公司的具体需求。企业通常有着多样化的数据保护要求,例如保护 Microsoft 365 等关键应用&#x…

作者头像 李华