没法优化,
只有树状数组、线段树和ST表能AC
给你个线段树代码
自己体会去吧
```cpp
#include <cstdio>
inline int min(int i,int j){
return i<j?i:j;
}
int n,m,a[2000004],tree[8000003],p;
inline void read(int &x){
x=0;int k=1;char ch=getchar();
while(ch<'0'||ch>'9') {if(ch=='-') k=-1;ch=getchar();}
while(ch<='9'&&ch>='0') {x=(x<<3)+(x<<1)+ch-48;ch=getchar();}
return;
}
void build(int k,int l,int r){
if(l==r) {
tree[k]=a[l];return;
}
int mid=l+r>>1;
build(k<<1,l,mid);
build(k<<1|1,mid+1,r);
tree[k]=min(tree[k<<1],tree[k<<1|1]);
}
const int oo=2147483640;
int minn(int k,int l,int r,int x,int y){
if(l>y||r<x)return oo;
if(x<=l&&r<=y) return tree[k];
int mid=l+r>>1,res;
res=min(minn(k<<1,l,mid,x,y),minn(k<<1|1,mid+1,r,x,y));
return res;
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++) read(a[i]);
build(1,1,n);
printf("0\n");
for(int i=2;i<=n;i++){
p=i-m>1?i-m:1;
printf("%d\n",minn(1,1,n,p,i-1));
}
return 0;
}
```
by RAYMOND_7 @ 2019-11-15 08:54:00