当前位置:   article > 正文

Lucky Days -codeforce

codeforces luckydays

题意

1083557-20181113211138825-138677520.png

题解

线段[la+kta,ra+kta][lb+ktb,rb+ktb]相交,可以建立一个不等式:

lbyrb

yla+kta(mod(tb))

转化一下:

y=la+kta+htb

k,h都是变量,那么由欧几里得扩展可知:k,h存在时,gcd(ta,tb)|(yla)。至此,问题转化为在区间[lb,rb],寻找一个y值使得gcd(ta,tb)|(yla)。如果是枚举区间内的数,复杂度会炸。稍微思考一下,不需要枚举整个区间的数,考察y=lby=y,ylagcd(ta,tb)=lblagcd(ta,tb)+1。令t=lblagcd(ta,tb),那么可以解得:
y=tgcd(ta,tb)+la

y=(t+1)gcd(ta,tb)+la

代码

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int la, ra, ta, lb, rb, tb;
  4. int main()
  5. {
  6. cin >> la >> ra >> ta >> lb >> rb >> tb;
  7. if (la > lb) {
  8. swap(la, lb);
  9. swap(ra, rb);
  10. swap(ta, tb);
  11. }
  12. int g = __gcd(ta, tb);
  13. int k = (lb - la) / g;
  14. int l = ra - la;
  15. int ans = 0;
  16. ans = max(ans, min(la + g * k + l, rb) - max(la + g * k, lb) + 1);
  17. k++;
  18. ans = max(ans, min(la + g * k + l, rb) - max(la + g * k, lb) + 1);
  19. cout << ans << endl;
  20. return 0;
  21. }

转载于:https://www.cnblogs.com/zgglj-com/p/9954788.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/75785
推荐阅读
相关标签
  

闽ICP备14008679号