#include<bits/stdc++.h>
using namespace std;
const int maxn=;
int a,b,n,m,s[maxn];
struct NODE{int maxval,minval;}t[maxn<<];
void build(int l,int r,int x){//建树
int mid=(l+r)>>;
if(l==r){t[x].maxval=t[x].minval=s[mid];return;}
build(l,mid,x<<);
build(mid+,r,x<<|);
t[x].maxval=max(t[x<<].maxval,t[x<<|].maxval);//父节点的值为左右孩子的最大值
t[x].minval=min(t[x<<].minval,t[x<<|].minval);//父节点的值为左右孩子的最小值
}
int query1(int l,int r,int x){//查询区间最大值
if(a<=l&&b>=r)return t[x].maxval;
else{
int mid=(l+r)>>;
if(b<=mid)return query1(l,mid,x<<);
else if(a>mid)return query1(mid+,r,x<<|);
else return max(query1(l,mid,x<<),query1(mid+,r,x<<|));
}
}
int query2(int l,int r,int x){//查询区间最小值
if(a<=l&&b>=r)return t[x].minval;
else{
int mid=(l+r)>>;
if(b<=mid)return query2(l,mid,x<<);
else if(a>mid)return query2(mid+,r,x<<|);
else return min(query2(l,mid,x<<),query2(mid+,r,x<<|));
}
}
int main(){
while(~scanf("%d %d",&n,&m)){
for(int i=;i<=n;++i)scanf("%d",&s[i]);
memset(t,,sizeof(t));//清0
build(,n,);//建树
while(m--){
scanf("%d %d",&a,&b);
printf("%d\n",query1(,n,)-query2(,n,));
}
}
return ;
}