题意:就是一个区间k向右移动,然后先输出区间每次移动后的区间里面最小的,结束后,换行,再下来再输出最大的
题解:板子st表
#include<cstdio> #include<algorithm> #include<iostream> using namespace std; int n,k; int dmax[1000001],dmin[1000001]; int init() //预处理 { int j=1; for(j=1;j*2<=k;j*=2) { for(int i=0;i+j<n;i++) { dmin[i]=min(dmin[i+j],dmin[i]); dmax[i]=max(dmax[i+j],dmax[i]); } } return j; } int main() { ios::sync_with_stdio(false); cin>>n>>k; for(int i=0;i<n;i++) { cin>>dmin[i]; dmax[i]=dmin[i]; } int j=init(); //保存求得的最大j for(int i=0;i+k<=n;i++) { cout<<min(dmin[i],dmin[i+k-j])<<' '; } cout<<endl; for(int i=0;i+k<=n;i++) { cout<<max(dmax[i],dmax[i+k-j])<<' '; } cout<<endl; return 0; }
本题多解:线段树,树状数组,单调栈都行(线段树90%........)