HDU 5381 The sum of gcd

对于每一个i,求出若干区间[l1,r1],[l2,r2],[l3,r3]...满足gcd(l1~i)~gcd(r1~i)一样,gcd(l2~i)~gcd(r2,i)一样...

则以i为右区间的全部gcd和为sum[i] = (r1 - l1 + 1) * g1 + (r2 - l2 + 1) * g2 + ...

同理求出i右边的一段段同gcd区间[l11,r11],[l22,r22],[l33,r33]...

然后将询问按左区间排序。int p初始设为1。对于p <= i < L,要消除i对全部前缀和的影响,仅仅要[l11,r11]的sum[]减去g11,[l22,r22]的sum[]减去g22...

p = L

ans = [L,R]的sum和

求i的区间时,先保留i-1求出的区间,然后A[i]和每一个区间的g求gcd,该合并的合并

(队友A的,就不贴他优雅的代码了, 红红火火恍恍惚惚)



posted @ 2017-08-03 10:51  lytwajue  阅读(153)  评论(0编辑  收藏  举报