P1886 滑动窗口 /【模板】单调队列
有一个长为n的序列a,以及一个大小为k的窗口。现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的最大值和最小值。
例如:
The array is [1,3,-1,-3,5,3,6,7], and k = 3。
输入格式
输入一共有两行,第一行有两个正整数 n,kn,k。 第二行 nn 个整数,表示序列 aa
输出格式
输出共两行,第一行为每次窗口滑动的最小值
第二行为每次窗口滑动的最大值
输入输出样例
输入
8 3
1 3 -1 -3 5 3 6 7
输出
-1 -3 -3 -3 3 3
3 3 5 5 6 7
分析:
这道题是一道单调队列的模板题,给定一个固定区间为k,求区间的最大值,我们来看i,j两个数,i.id<j.id,i.val<j.val。那么按理来说i就是一个无用元素,因为随着窗口的移动,i一定会比j先移出去!!
这样,考虑构造一个单调递增的队列,存放相应的序号,当a[队尾]>=要入队数据a[i],删除队尾元素;当队头<=i-k时,删除队头元素。
#include<cstdio>
#include<iostream>
#include<cmath>