QMD ST表 倍增

时间:2023-05-31 17:07:37
#include<iostream>
#include<cmath>
using namespace std;
const int maxn=1e5+;
int a[maxn];
int st[maxn][];
int ST[maxn][];
int quick(int a,int n)
{
int ans=;
while(n)
{
if(n&) ans*=a;
a=a*a;
n>>;
}
return ans;
}
int main()
{
int n,m; cin>>n>>m;
for(int i=;i<=n;i++) cin>>a[i];
for(int i=n;i>=;i--)
{
for(int j=;i+(<<j-)-<=n;j++)
{
if(j==) { st[i][j]=a[i]; ST[i][j]=a[i]; }
else
{
st[i][j]=max(st[i][j-],st[i+(<<j-)][j-]);
ST[i][j]=min(ST[i][j-],ST[i+(<<j-)][j-]);
}
}
}
//cout<<n<<m<<endl;
while(m--)
{
int l,r; cin>>l>>r;
int k=floor(log(r-l+));
int a=max(st[l][k],st[r-(<<k)+][k]);
int b=min(ST[l][k],ST[r-(<<k)+][k]);
cout<<a-b<<endl;
}
return ;
}