题目大意如下:给定一个序列,每个序列有值xi,现给定t个数列,对于每个长n的数列,求一段[l,r]使 [r-l+1]*gcd(l,r)最大,gcd(l,r)指的是该连续区间的最大公约数. 不难想到n^3,n^2logx,n^2的暴力吧 n^3DP,n^2logx暴力枚举,n^2DP 可以这样考虑,每次我对于某一个数,保存若干个值,以i为右端点的区间且gcd为某一值的时候这个区间最大的左端点位置是哪里? 但是你也许会认为这样做状态会不会有点多?更新是不是n方的呢? 其实不是的,因为我们可以从左到右…