news 2026/4/18 10:54:11

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷 P1886 【模板】单调队列 / 滑动窗口

题目描述

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

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

窗口位置[1 3 -1] -3 5 3 6 7 1 [3 -1 -3] 5 3 6 7 1 3 [-1 -3 5] 3 6 7 1 3 -1 [-3 5 3] 6 7 1 3 -1 -3 [5 3 6] 7 1 3 -1 -3 5 [3 6 7]​最小值−1−3−3−333​最大值335567​​

输入格式

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

输出格式

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

输入输出样例

输入 #1复制

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

输出 #1复制

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

说明/提示

【数据范围】
对于 50% 的数据,1≤n≤105;
对于 100% 的数据,1≤k≤n≤106,ai​∈[−231,231)。

#include<bits/stdc++.h> using namespace std; const int N=1e6+10; int a[N],q[N]; int a1,k; int main() { scanf("%d%d",&a1,&k); for(int i=0;i<a1;i++) scanf("%d",&a[i]); int hh=0,tt=-1; for(int i=0;i<a1;i++) { if(hh<=tt&&i-k+1>q[hh]) hh++; while(hh<=tt&&a[q[tt]]>=a[i]) { tt--; } q[++tt]=i; if(i>=k-1) printf("%d ",a[q[hh]]); } puts(""); hh=0,tt=-1; for(int i=0;i<a1;i++) { if(hh<=tt&&i-k+1>q[hh]) hh++; while(hh<=tt&&a[q[tt]]<=a[i]) { tt--; } q[++tt]=i; if(i>=k-1) printf("%d ",a[q[hh]]); } puts(""); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 5:33:53

Windows虚拟显示器完整指南:免费扩展你的桌面空间

Windows虚拟显示器完整指南&#xff1a;免费扩展你的桌面空间 【免费下载链接】virtual-display-rs A Windows virtual display driver to add multiple virtual monitors to your PC! For Win10. Works with VR, obs, streaming software, etc 项目地址: https://gitcode.co…

作者头像 李华
网站建设 2026/4/16 11:29:23

桌面版脑图完整使用教程:跨平台思维导图解决方案

桌面版脑图完整使用教程&#xff1a;跨平台思维导图解决方案 【免费下载链接】DesktopNaotu 桌面版脑图 (百度脑图离线版&#xff0c;思维导图) 跨平台支持 Windows/Linux/Mac OS. (A cross-platform multilingual Mind Map Tool) 项目地址: https://gitcode.com/gh_mirrors/…

作者头像 李华
网站建设 2026/4/18 5:33:52

基于51单片机的频率可调多波形函数发生器设计与实现

系统总体设计概述 点击下载设计资料&#xff1a;https://download.csdn.net/download/m0_51061483/91926361 1.1 设计背景与研究意义 函数发生器是电子实验、电子测量以及自动化教学中常用的基础仪器之一&#xff0c;能够输出多种标准波形信号&#xff0c;为电路调试、系统测…

作者头像 李华
网站建设 2026/4/18 5:40:02

Sunshine游戏串流实战指南:从零搭建到极致体验

Sunshine游戏串流实战指南&#xff1a;从零搭建到极致体验 【免费下载链接】Sunshine Sunshine: Sunshine是一个自托管的游戏流媒体服务器&#xff0c;支持通过Moonlight在各种设备上进行低延迟的游戏串流。 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine …

作者头像 李华
网站建设 2026/4/18 5:35:02

33、U-Boot使用指南:环境变量、脚本、镜像与启动配置

U-Boot使用指南:环境变量、脚本、镜像与启动配置 1. U-Boot环境变量的使用 U-Boot启动并运行后,可通过设置适当的环境变量进行配置,其环境变量的使用与Unix shell(如bash)类似。使用 printenv 命令可查看目标设备上环境变量的当前值,以下是OpenMoko GTA01开发硬件上的…

作者头像 李华