思路
这道题其实就把上一题ST表的 max \max max 改成 gcd \gcd gcd 就好了。
代码
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
long long n,m,a[800010],l,r,f[1000010][50];
int gcd(int x,int y)
{
if(y==0)
return x;
gcd(y,x%y);
}
int main()
{
cin>>n>>m;
for(int i=1; i<=n; i++)
scanf("%lld",&a[i]);
for(int i=1; i<=n; i++)
f[i][0]=a[i];
for(int j=1; j<=log2(n); j++)
for(int i=1; i+(1<<j)-1<=n; i++)
f[i][j]=gcd(f[i][j-1],f[i+(1<<(j-1))][j-1]);
for(int i=1; i<=m; i++)
{
scanf("%lld%lld",&l,&r);
int k=log2(r-l+1);
printf("%lld\n",gcd(f[l][k],f[r-(1<<k)+1][k]));
}
return 0;
}