#include <bits/stdc++.h>
using namespace std;
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;
}
const int N = 1e6+5;
int Log2(int x)
{
int i=0;
int temp=1;
while(temp<=x)
{
temp<<=1;
i++;
}
return i-1;
}
const int bound=Log2(int(1e6+5));
int Max[N][25];
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()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int n;
int m;
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%d",&Max[i][0]);
}
for(int j=1;j<25;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,r;
l=read();
r=read();
printf("%d\n",query(l,r));
}
}