news 2026/4/3 6:23:28

算法竞赛备考冲刺必刷题(C++) | 洛谷 P1886 单调队列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法竞赛备考冲刺必刷题(C++) | 洛谷 P1886 单调队列

本文分享的必刷题目是从蓝桥云课洛谷AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。

欢迎大家订阅我的专栏:算法题解:C++与Python实现!

附上汇总贴:算法竞赛备考冲刺必刷题(C++) | 汇总


【题目来源】

洛谷:P1886 【模板】单调队列 / 滑动窗口 - 洛谷

【题目描述】

有一个长为 n 的序列 a,以及一个大小为 k 的窗口。现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的最大值和最小值。

例如,对于序列 [1,3,−1,−3,5,3,6,7] 以及 k=3,有如下过程:

【输入】

输入一共有两行,第一行有两个正整数 n,k。 第二行 n 个整数,表示序列 a

【输出】

输出共两行,第一行为每次窗口滑动的最小值
第二行为每次窗口滑动的最大值

【输入样例】

8 3 1 3 -1 -3 5 3 6 7

【输出样例】

-1 -3 -3 -3 3 3 3 3 5 5 6 7

【算法标签】

《洛谷 P1886 单调队列》 #模拟# #线段树# #单调队列# #队列#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=1000006;inta[N],q[N];// a: 输入数组, q: 单调队列(存储下标)intn,k;// n: 数组长度, k: 滑动窗口大小intmain(){cin>>n>>k;// 读入n和k// 读入数组for(inti=1;i<=n;i++)cin>>a[i];// 第一部分:维护窗口最小值inth=1,t=0;// h: 队头指针, t: 队尾指针, 初始队列为空for(inti=1;i<=n;i++){// 维护队列单调递增// 当队列非空且队尾对应的值 >= 当前值时,弹出队尾while(h<=t&&a[q[t]]>=a[i])t--;// 将当前下标加入队尾q[++t]=i;// 如果队头元素已经不在当前窗口内,弹出队头if(q[h]<i-k+1)h++;// 当窗口形成时(i >= k),输出当前窗口的最小值if(i>=k)cout<<a[q[h]]<<" ";}cout<<endl;// 第二部分:维护窗口最大值h=1,t=0;// 重置队列for(inti=1;i<=n;i++){// 维护队列单调递减// 当队列非空且队尾对应的值 <= 当前值时,弹出队尾while(h<=t&&a[q[t]]<=a[i])t--;// 将当前下标加入队尾q[++t]=i;// 如果队头元素已经不在当前窗口内,弹出队头if(q[h]<i-k+1)h++;// 当窗口形成时(i >= k),输出当前窗口的最大值if(i>=k)cout<<a[q[h]]<<" ";}cout<<endl;return0;}
// 使用acwing模板二刷#include<bits/stdc++.h>usingnamespacestd;constintN=1000005;intn,k,a[N],q[N];// a: 输入数组, q: 单调队列(存储下标)intmain(){cin>>n>>k;// 读入数组长度和窗口大小// 读入数组元素for(inti=1;i<=n;i++)cin>>a[i];// 第一部分:求滑动窗口最小值inthh=0,tt=-1;// 队列初始化: hh-队头, tt-队尾, 空队列时hh>ttfor(inti=1;i<=n;i++){// 1. 维护窗口范围: 如果队头元素不在窗口内,弹出队头if(hh<=tt&&q[hh]<i-k+1)hh++;// 2. 维护队列单调性: 保持队列单调递增while(hh<=tt&&a[q[tt]]>=a[i])tt--;// 3. 当前下标入队q[++tt]=i;// 4. 当窗口形成时,输出当前窗口最小值(队头元素)if(i>=k)cout<<a[q[hh]]<<" ";}cout<<endl;// 第二部分:求滑动窗口最大值hh=0,tt=-1;// 重置队列for(inti=1;i<=n;i++){// 1. 维护窗口范围if(hh<=tt&&q[hh]<i-k+1)hh++;// 2. 维护队列单调性: 保持队列单调递减(求最大值)while(hh<=tt&&a[q[tt]]<=a[i])tt--;// 3. 当前下标入队q[++tt]=i;// 4. 当窗口形成时,输出当前窗口最大值(队头元素)if(i>=k)cout<<a[q[hh]]<<" ";}cout<<endl;return0;}

【运行结果】

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

技术写作新姿势:自动为教程文章生成配套示意图

技术写作新姿势&#xff1a;自动为教程文章生成配套示意图 作为一名长期与技术文档打交道的工程师&#xff0c;我深知反复截屏、修图、调整格式的痛苦。每次更新文档版本&#xff0c;都要重新制作示意图&#xff0c;不仅耗时耗力&#xff0c;还难以保持视觉风格的一致性。今天我…

作者头像 李华
网站建设 2026/3/29 2:46:23

WVG实战手册:从DRM技术新手到精通高手的进阶指南

WVG实战手册&#xff1a;从DRM技术新手到精通高手的进阶指南 【免费下载链接】wvg 项目地址: https://gitcode.com/gh_mirrors/wv/wvg 你是否曾经对DRM技术感到困惑&#xff1f;面对复杂的加密流程和许可证交换机制&#xff0c;是否觉得无从下手&#xff1f;现在&#…

作者头像 李华
网站建设 2026/3/27 12:01:40

学术翻译革命:Zotero智能翻译插件实现英文文献高效中文化

学术翻译革命&#xff1a;Zotero智能翻译插件实现英文文献高效中文化 【免费下载链接】zotero-pdf2zh PDF2zh for Zotero | Zotero PDF中文翻译插件 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-pdf2zh 面对海量英文文献的阅读压力&#xff0c;科研工作者常常陷…

作者头像 李华
网站建设 2026/4/1 10:58:48

从零精通Rufus:USB启动盘制作全流程实战指南

从零精通Rufus&#xff1a;USB启动盘制作全流程实战指南 【免费下载链接】rufus The Reliable USB Formatting Utility 项目地址: https://gitcode.com/GitHub_Trending/ru/rufus 在系统维护、数据恢复和操作系统安装过程中&#xff0c;一个可靠的USB启动盘是每个技术人…

作者头像 李华
网站建设 2026/3/30 20:50:10

Z-Image-Turbo商业应用验证:48小时快速原型开发方案

Z-Image-Turbo商业应用验证&#xff1a;48小时快速原型开发方案 为什么选择Z-Image-Turbo进行商业原型验证 作为一名创业者&#xff0c;当你需要快速验证一个基于AI图像生成的商业创意时&#xff0c;Z-Image-Turbo无疑是最佳选择之一。这个由阿里通义团队开源的图像生成模型&am…

作者头像 李华
网站建设 2026/4/2 0:44:17

CRNN vs 传统OCR:为什么它在中文识别上更胜一筹?

CRNN vs 传统OCR&#xff1a;为什么它在中文识别上更胜一筹&#xff1f; &#x1f4d6; OCR 文字识别的技术演进与挑战 光学字符识别&#xff08;Optical Character Recognition, OCR&#xff09;是将图像中的文字内容转化为可编辑文本的核心技术&#xff0c;广泛应用于文档数字…

作者头像 李华