【模板】ST表
st表版子题
#include<cstdio> #include<cmath> #include<algorithm> using namespace std; const int MAXN=1e6+10; inline int read() { char c=getchar();int x=0,f=1; while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();} while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();} return x*f; } int Max[MAXN][21]; int Query(int l,int r) { int k=log2(r-l+1); return max(Max[l][k],Max[r-(1<<k)+1][k]); } int main() { #ifdef WIN32 freopen("a.in","r",stdin); #endif int N=read(),M=read(); for(int i=1;i<=N;i++) Max[i][0]=read(); for(int j=1;j<=21;j++) for(int i=1;i+(1<<j)-1<=N;i++) Max[i][j]=max(Max[i][j-1],Max[i+(1<<(j-1))][j-1]); for(int i=1;i<=M;i++) { int l=read(),r=read(); printf("%d\n",Query(l,r)); } return 0; }