news 2026/4/23 17:40:44

算法竞赛备考冲刺必刷题(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/23 8:16:56

探索高效3D点云标注:5大创新功能深度体验

探索高效3D点云标注&#xff1a;5大创新功能深度体验 【免费下载链接】point-cloud-annotation-tool 项目地址: https://gitcode.com/gh_mirrors/po/point-cloud-annotation-tool 在自动驾驶技术飞速发展的今天&#xff0c;如何快速准确地标注海量激光雷达点云数据&…

作者头像 李华
网站建设 2026/4/23 8:17:00

AltStore完全解锁指南:突破iOS限制自由安装应用

AltStore完全解锁指南&#xff1a;突破iOS限制自由安装应用 【免费下载链接】AltStore AltStore is an alternative app store for non-jailbroken iOS devices. 项目地址: https://gitcode.com/gh_mirrors/al/AltStore 想要在未越狱的iPhone上安装任意应用吗&#xff1…

作者头像 李华
网站建设 2026/4/23 8:32:15

BongoCat神奇桌面伴侣:让键盘敲击变身为视觉盛宴

BongoCat神奇桌面伴侣&#xff1a;让键盘敲击变身为视觉盛宴 【免费下载链接】BongoCat 让呆萌可爱的 Bongo Cat 陪伴你的键盘敲击与鼠标操作&#xff0c;每一次输入都充满趣味与活力&#xff01; 项目地址: https://gitcode.com/gh_mirrors/bong/BongoCat 厌倦了单调的…

作者头像 李华
网站建设 2026/4/23 9:53:31

完全掌握离线音频转录:Buzz实战应用深度解析

完全掌握离线音频转录&#xff1a;Buzz实战应用深度解析 【免费下载链接】buzz Buzz transcribes and translates audio offline on your personal computer. Powered by OpenAIs Whisper. 项目地址: https://gitcode.com/GitHub_Trending/buz/buzz 还在为音频转录的隐私…

作者头像 李华
网站建设 2026/4/23 12:34:19

CRNN模型解释性研究:理解OCR决策过程

CRNN模型解释性研究&#xff1a;理解OCR决策过程 &#x1f4d6; 项目简介 在现代信息处理系统中&#xff0c;光学字符识别&#xff08;OCR&#xff09; 是连接物理世界与数字世界的桥梁。从扫描文档到智能表单填写&#xff0c;从发票识别到路牌解析&#xff0c;OCR 技术已深度嵌…

作者头像 李华
网站建设 2026/4/23 9:55:45

3D点云智能标注终极指南:从零开始掌握高效数据标注

3D点云智能标注终极指南&#xff1a;从零开始掌握高效数据标注 【免费下载链接】point-cloud-annotation-tool 项目地址: https://gitcode.com/gh_mirrors/po/point-cloud-annotation-tool 在自动驾驶和机器人视觉领域&#xff0c;高质量的点云数据标注已成为算法训练的…

作者头像 李华