单调队列的实现

         这是C++算法基础-数据结构专栏的第二十五篇文章,专栏详情请见此处


引入

        单调队列就是满足单调性的队列,它最经典的应用就是给定一个序列和一个窗口,使窗口在序列中从前向后滑动,求出窗口在每个位置时,其中元素的最大/小值。

        下面我们就来讲单调队列的实现。

定义

        单调队列就是满足单调性的队列结构,也就是说,其中的元素具有单调性,但是存储的方法和基本操作与队列一样。(其实,这里说的队列和我在队列的实现中讲解的队列有区别,稍后会提到)

过程

        例题

        我们从引入中所提到的一个经典问题来学习单调队列。

        题目大意:给定一个序列和一个窗口,使窗口在序列中从前向后滑动,求出窗口在每个位置时,其中元素的最小值和最大值。

        首先,我们把最小值和最大值分开来做,这里我们用求最小值来讲解。

        仔细思考,在数组a中,若有i<j,且a_{i}\geq a_{j},那么很明显,当a_{j}进入窗口中时,a_{i}肯定不会是窗口中的最小值,而且只要a_{i}还在窗口中,那么a_{j}一定也在窗口中。从这点来看,对于求窗口中的最小值的过程中可能有贡献的数,在数组中是一个单调递增的序列(性质1)。

        在窗口滑动一次后,首先就是判断序列最前面的元素是否出窗口,这时,如果我们在这个序列中存储数值,那就无法判断是否出窗口了,所以我们需要在序列中存储下标(性质2)。

        然后要做的就是解决序列最后面的元素与当前滑进来的元素是否满足单调性的问题,如果序列最后面的一些元素不满足单调性,那么我们就将这些元素删除,最后将这个元素放在序列最后的位置(性质3)。

        我们可以看出性质2、3,分别说明了数据可以从序列的尾部进,两端出,说明这个数据结构不是普通的队列,而是一种双向队列,再结合性质1,我们就想到了用单调队列这一数据结构。

        单调队列主体过程

        上面的例题让大家更加了解单调队列的性质和使用方法,这个章节我们就开始讲解单调队列的主体过程了。

         首先,虽然单调队列本质上是双向队列,但它也是队列,双向队列只是在普通队列的基础上增加了一个插入数据的方向,单调队列的基本操作和普通队列基本是一样的,如果想了解具体内容,可以移步至我的这篇博客:队列的实现。

        在这里就不再详细讲解,只讲解单调队列相比于普通的队列所特有的操作qwq

        其实在例题中也能明白单调队列的过程:当数据进入单调队列时,先解决队首是否出窗口的问题,再解决队尾与当前元素是否满足单调性的问题,最后将当前元素下标插入队尾。

代码

        下面给出单调队列的实现代码:

int que[N],hh=0,tt=-1;for (int i=0;i<n;i++){while(hh<=tt&&check_out(que[hh])) hh++;while(hh<=tt&&check(que[tt],i)) tt--;q[++tt]=i;
}
        代码解释

        第一行中,que[]是用数组模拟的队列,hh表示队头,tt表示队尾;for循环内部是维护单调队列的过程;check_out()函数的作用是判断队头是否弹出;check()函数的作用是判断队列内维护的数据应该具有的性质(也就是对当前数据是否能入队列作出判断)。


上一篇-单调栈的实现    C++算法基础专栏文章    下一篇-KMP算法的实现


每周六更新一篇文章,内容一般是自己总结的经验或是在其他网站上整理的优质内容

点个赞,关注一下呗~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1534155.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

STM32启用FPU浮点运算

这篇文章产生背景&#xff1a;其他人的文章太杂了&#xff0c;对我这种菜鸡无法接受&#xff1b; 参考文章&#xff1a; stm32h743单片机嵌入式学习笔记7-FPU_stmh743vit4-CSDN博客 stm32F407 打开 FPU(浮点运算处理器)_stm32f407开启fpu-CSDN博客 STM32F4CubeMXHal库下使能…

第J1周:ResNet-50算法实战与解析

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 文章目录 一、前期工作1、ResNet-50总体结构2、设置GPU3、导入数据 二、数据预处理1、加载数据2、可视化数据3、再次检查数据4、配置数据集 三、构建ResNet-50…

初级练习[2]:Hive SQL查询汇总分析

目录 SQL查询汇总分析 成绩查询 查询编号为“02”的课程的总成绩 查询参加考试的学生个数 分组查询 查询各科成绩最高和最低的分 查询每门课程有多少学生参加了考试(有考试成绩) 查询男生、女生人数 分组结果的条件 查询平均成绩大于60分的学生的学号和平均成绩 查询至少…

基于python+django+vue的农业管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于pythondjangovueMySQL的农…

C++ push_back和emplace_back的区别

基本类型情况西&#xff0c;两者几乎没什么区别 但是再自定义类型的时候&#xff1f;emplace——back更高效&#xff0c;但是emplace_back 没有类型检查的安全&#xff1b;只有运行时候才会报错。 #include <vector> #include <iostream> using namespace std; …

基于 CycleGAN 对抗网络的自定义数据集训练

目录 生成对抗网络&#xff08;GAN&#xff09; CycleGAN模型训练 训练数据生成 下载开源项目CycleGAN 配置训练环境 开始训练 模型测试 可视化结果 生成对抗网络&#xff08;GAN&#xff09; 首先介绍一下什么是GAN网络&#xff0c;它是由生成器&#xff08;Generator…

分类预测|基于差分优化DE-支持向量机数据分类预测完整Matlab程序 DE-SVM

分类预测|基于差分优化DE-支持向量机数据分类预测完整Matlab程序 DE-SVM 文章目录 一、基本原理DE-SVM 分类预测原理和流程总结 二、实验结果三、核心代码四、代码获取五、总结 一、基本原理 DE-SVM 分类预测原理和流程 1. 差分进化优化算法&#xff08;DE&#xff09; 原理…

【运维监控】Prometheus+grafana监控tomcat运行情况

运维监控系列文章入口&#xff1a;【运维监控】系列文章汇总索引 文章目录 一、prometheus二、grafana三、tomcat与jmx_exporter配置1、下载jmx_exporter2、部署jmx_exporter3、添加tomcat的配置信息4、修改tomcat的启动文件5、重启tomcat及验证6、其他 四、集成prometheus与gr…

vue3 动态 svg 图标使用

前言 在做后台管理系统中,我们经常会用到很多图标,比如左侧菜单栏的图标 当然这里 element-ui 或者 element-plus 组件库都会提供图标 但是在有些情况下 element-ui 或者 element-plus 组件库提供的图标满足不了我们的需求时,这个时候我们就需要自己去网上找一些素材或者…

CAN通讯常见错误

CAN通讯常见错误 1.在使用CAN设备进行数据通讯时&#xff0c;有时候参数配置不当可能就会导致通讯的失败&#xff0c;如下图1所示&#xff0c;出现通信错误的原因是两个设备的波特率配置不一致导致。 图1 2.有时候在配置参数的时候&#xff0c;不能只关注波特率速度配置一致…

JEE 设计模式

Java 数据访问对象模式 Java设计模式 - 数据访问对象模式 数据访问对象模式或DAO模式将数据访问API与高级业务服务分离。 DAO模式通常具有以下接口和类。 数据访问对象接口定义模型对象的标准操作。 数据访问对象类实现以上接口。可能有多个实现&#xff0c;例如&#xff0c…

关于Redis缓存一致性问题的优化和实践

目录标题 导语正文分布式场景下无法做到强一致即使是达到最终一致性也很难缓存的一致性问题缓存是如何写入的 如何感知数据库的变化最佳实践一&#xff1a;数据库变更后失效缓存最佳实践二&#xff1a;带版本写入 总结与展望阿里XKV腾讯DCache 导语 Redis缓存一致性的问题是经…

【API安全】威胁猎人发布超大流量解决方案

随着数字化进程加速&#xff0c;企业API接口数量激增&#xff0c;已经成为连接内外部服务的重要桥梁。然而&#xff0c;对于拥有庞大的外部客户群体和错综复杂的内部业务系统的大型企业而言&#xff0c;API安全管控面临超大流量下的性能瓶颈与数据安全双重挑战。 性能上&#…

【软件测试】常用的开发、测试模型

哈喽&#xff0c;哈喽&#xff0c;大家好~ 我是你们的老朋友&#xff1a;保护小周ღ 今天给大家带来的是 【软件测试】常用的开发、测试模型&#xff0c;首先了解, 什么是软件的生命周期, 测试的生命周期, 常见的开发模型: 瀑布, 螺旋, 增量, 迭代, 敏捷. 常用的测试模型, …

Serverless 安全新杀器:云安全中心护航容器安全

作者&#xff1a;胡志广(独鳌) 云安全中心对于 Serverless 容器用户的价值 从云计算发展之初&#xff0c;各大云厂商及传统安全厂商就开始围绕云计算的形态来做安全解决方案。传统安全与云计算安全的形态与做法开始发生变化&#xff0c;同时随着这 10 多年的发展&#xff0c;…

ThreeJS入门(002):学习思维路径

查看本专栏目录 - 本文是第 002篇入门文章 文章目录 如何使用这个思维导图 Three.js 学习思维导图可以帮助你系统地了解 Three.js 的各个组成部分及其关系。下面是一个简化的 Three.js 学习路径思维导图概述&#xff0c;它包含了学习 Three.js 的主要概念和组件。你可以根据这个…

Redis 入门 - 收官

《Redis 入门》系列文章总算完成了&#xff0c;希望这个系列文章可以想入门或刚入门的同学提供帮助&#xff0c;希望能让你形成学习Redis系统性概念。 当时为什么要写这个系列文章&#xff0c;是因为我自己就是迷迷糊糊一路踩坑走过来的&#xff0c;我踩完的坑就踩完了&#x…

Kamailio-基于Zabbix+Kamcli的SIP指标监控

什么是Kamailio? Kamailio 是一个开源的 Session Initiation Protocol (SIP) 服务器&#xff0c;它主要用于建立和管理实时通信会话&#xff0c;如语音和视频通话&#xff0c;与opensips这个产品是同根同源的存在。它们相似&#xff0c;没有更好&#xff0c;是有更合适。 此…

LLM - 理解 多模态大语言模型 (MLLM) 的指令微调与相关技术 (四)

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/142063880 免责声明&#xff1a;本文来源于个人知识与公开资料&#xff0c;仅用于学术交流&#xff0c;欢迎讨论&#xff0c;不支持转载。 完备(F…

获取京东商品详情数据API接口优惠券信息(通过商品id获取商品详情页数据)调用说明文档

在当今数字化时代&#xff0c;应用程序之间的互操作性已成为推动业务创新和技术进步的关键因素。API&#xff08;Application Programming Interface&#xff0c;应用程序编程接口&#xff09;作为这一生态系统中不可或缺的一环&#xff0c;扮演着连接不同软件服务、数据资源和…