首页 > 其他 > 详细

HDU 5381 The sum of gcd

时间:2015-08-13 22:28:34      阅读:1136      评论:0      收藏:0      [点我收藏+]

对于每个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的,就不贴他优雅的代码了, 红红火火恍恍惚惚)



版权声明:本文为博主原创文章,未经博主允许不得转载。

HDU 5381 The sum of gcd

原文:http://blog.csdn.net/u012848726/article/details/47617819

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!