本文共 881 字,大约阅读时间需要 2 分钟。
这个裸题,滑动窗口求最大最小值,单调队列来两边,一次单调递增q[s]就是最小值,一次单调递减q[s]就是最大值
cin会超时,解除同步也没用。。。
#include#include #include #include #include #include #include #include #include #include #include #include #include #define pi acos(-1)#define ll long long#define mod 1000000007#define ls l,m,rt<<1#define rs m+1,r,rt<<1|1#pragma comment(linker, "/STACK:1024000000,1024000000")using namespace std;const double g=10.0,eps=1e-9;const int N=1000000+10,maxn=500+100,inf=0x3f3f3f;int a[N],q[N];int minn[N],maxx[N];int main(){ /* ios::sync_with_stdio(false); cin.tie(0);*/ int n,k; while(~scanf("%d%d",&n,&k)){ for(int i=0;i a[q[t-1]])t--; q[t++]=i; if(s =k)s++; /* for(int j=s;j < <<" "; cout< =k)s++; /* for(int j=s;j < <<" "; cout<
转载于:https://www.cnblogs.com/acjiumeng/p/7158117.html