【队列的算法题记录】239. 滑动窗口最大值

2024-04-15 17:52

本文主要是介绍【队列的算法题记录】239. 滑动窗口最大值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

239. 滑动窗口最大值

题目链接

思路

提到滑动窗口就不难不想到队列,这题是要获得滑动窗口每一步的最大值,所以我们可以通过保证队列的单调性(即单调递减,使得最大值永远处在队列前端)来实现:

class MyQueue {public:deque<int> que; // 用deque来实现单调队列// 如果当前value和队列前端元素相等,就让队列前端元素出列void pop(int value) {if(!que.empty() && value == que.front()) {que.pop_front();}}/* 如果当前数值比队列入口处元素大,则要将队列后端的数值弹出,直到value小于队列入口处元素(保证单调递减)*/void push(int value) {while(!que.empty() && value > que.back()) {que.pop_back();}que.push_back(value);}// 获取队列中的最大值(永远在前端)int front() {return que.front();}}

上面用deque实现了我们需要的队列操作:pop、push和front。滑动窗口向后滑动时,pop可以弹出前端元素,push是加入后面的元素,front是获取当前队列中的最大值(因为我们实现的是单调递减队列)。

那么我们具体是怎么让元素出入列同时保持单调递减的呢?

  • 当滑动窗口滑动,要加入元素到队列时,首先看当前元素value与队列最后面的元素大小,如果value比它小,则直接加入value至队尾可以保证单调递减。如果value比它大,则要先让队尾元素出去,这里用的是while循环而不是if,我们要让比value小的都出队列,保证单调性。
  • 滑动窗口滑动,加入元素,也要弹出队列前端的元素,这里我们不能直接弹出,因为队列最前端放的是最大值,而它不一定是要出队列的那一个元素,所以在进行pop时,我们首先要判断前端元素是不是我们要pop出来的那个元素。

cpp代码

class Solution {
private:class MyQueue {public:deque<int> que; // 用deque来实现单调队列// 如果当前value和队列前端元素相等,就让队列前端元素出列void pop(int value) {if(!que.empty() && value == que.front()) {que.pop_front();}}/* 如果当前数值比队列入口处元素大,则要将队列后端的数值弹出,直到value小于队列入口处元素(保证单调递减)*/void push(int value) {while(!que.empty() && value > que.back()) {que.pop_back();}que.push_back(value);}// 获取队列中的最大值(永远在前端)int front() {return que.front();}}
public:vector<int> maxSlidingWindow(vector<int>& nums, int k) {MyQueue que;vector<int> result;for(int i = 0; i < k; i++) {    // 首先将nums的前k个元素加入队列que.push(nums[i]);}result.push_back(que.front());  // 取得初始窗口的最大值(获取单调队列的前端)for(int i = k; i < nums.size(); i++) {que.pop(nums[i-k]); // 滑动窗口移除最前面的元素que.push(nums[i]);  // 滑动窗口前加入最后面的元素result.push_back(que.front());  // 记录对应的最大值}
};

这篇关于【队列的算法题记录】239. 滑动窗口最大值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906504

相关文章

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2