Solution:
经典的单调队列模板题,我们可以用deque来实现。
首先,滑动窗口的size不能大于k,得:r-l<=k;
其次,当每个数进入队列时,若是求最大值,那么队列里比他小的数就不可能再成为答案,得:while(a[r]<=now && r>=0) r--;
分析完毕,上代码:
#include <bits/stdc++.h>
using namespace std;
const int N=2e6+5;
int n,k,a[N],mi[N],ma[N];
deque<int>q1,q2;
int main()
{
cin>>n>>k;
for(int i=1;i<=n;i++)
cin>>a[i];
for(int i=1;i<=n;i++)
{
while(q1.size()&&i-q1.front()>=k)
q1.pop_front();
while(q1.size()&&a[q1.back()]>=a[i])
q1.pop_back();
while(q2.size()&&i-q2.front()>=k)
q2.pop_front();
while(q2.size()&&a[q2.back()]<=a[i])
q2.pop_back();
q1.push_back(i);
q2.push_back(i);
if(i>=k)
{
mi[i]=a[q1.front()];
ma[i]=a[q2.front()];
}
}
for(int i=k;i<=n;i++)
cout<<mi[i]<<' ';
cout<<'\n';
for(int i=k;i<=n;i++)
cout<<ma[i]<<' ';
return 0;
}
京公网安备 11010502036488号