【CJOJ2512】gcd之和(莫比乌斯反演)

题面

给定\(n,m(n,m<=10^7)\)

\[\sum_{i=1}^n\sum_{j=1}^mgcd(i,j)
\]

题解

首先把公因数直接提出来

\[\sum_{d=1}^nd\sum_{i=1}^{n/d}\sum_{j=1}^{m/d}[gcd(i,j)==1]
\]

很明显

\[f(x)=\sum_{i=1}^{a}\sum_{j=1}^{b}[gcd(i,j)==x]
\]

\[g(x)=\sum_{x|d}f(d)
\]

\[g(x)=\sum_{i=1}^{a}\sum_{j=1}^{b}[x|gcd(i,j)]
\]

\[g(x)=\sum_{i=1}^{a/x}\sum_{j=1}^{b/x}[1|gcd(i,j)]
\]

\[g(x)=[\frac{a}{x}]·[\frac{b}{x}]
\]

很明显,可以对\(f(x)\)进行莫比乌斯反演,

\[f(x)=\sum_{i=1}^x\mu(i)g(i)
\]

可以数论分块算

所求的式子

\[ans=\sum_{d=1}^{n}df(1)
\]

其中,对于每一次计算的\(a,b\)

\(a=[\frac{n}{d}],b=[\frac{m}{d}]\)

这个也很显然可以数论分块

最后,总体复杂度\(O(n)\)

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<algorithm>
  7. #include<set>
  8. #include<map>
  9. #include<vector>
  10. #include<queue>
  11. using namespace std;
  12. #define MOD 998244353
  13. #define MAX 10000000
  14. inline int read()
  15. {
  16. int x=0,t=1;char ch=getchar();
  17. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  18. if(ch=='-')t=-1,ch=getchar();
  19. while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
  20. return x*t;
  21. }
  22. int n,m;
  23. bool zs[MAX+1000];
  24. int pri[MAX+1000],tot,mu[MAX+1000],smu[MAX+1000];
  25. long long ans;
  26. void pre()
  27. {
  28. zs[1]=true;mu[1]=1;
  29. for(int i=2;i<=MAX;++i)
  30. {
  31. if(!zs[i])pri[++tot]=i,mu[i]=-1;
  32. for(int j=1;j<=tot&&i*pri[j]<=MAX;++j)
  33. {
  34. zs[i*pri[j]]=true;
  35. if(i%pri[j]==0){mu[i*pri[j]]=0;break;}
  36. else mu[i*pri[j]]=-mu[i];
  37. }
  38. }
  39. for(int i=1;i<=MAX;++i)smu[i]=(smu[i-1]+mu[i])%MOD;
  40. }
  41. int Solve(int a,int b)
  42. {
  43. int i=1,j;
  44. long long ret=0;
  45. while(i<=a)
  46. {
  47. j=min(a/(a/i),b/(b/i));
  48. ret+=1ll*(smu[j]-smu[i-1]+MOD)%MOD*(a/i)%MOD*(b/i)%MOD;
  49. ret%=MOD;
  50. i=j+1;
  51. }
  52. return (ret+MOD)%MOD;
  53. }
  54. int main()
  55. {
  56. n=read();m=read();
  57. if(n>m)swap(n,m);
  58. int i=1,j;
  59. pre();
  60. while(i<=n)
  61. {
  62. j=min(n/(n/i),m/(m/i));
  63. int tt=1ll*(i+j)*(j-i+1)/2%MOD;
  64. ans+=1ll*tt*Solve(n/i,m/i);
  65. ans%=MOD;
  66. i=j+1;
  67. }
  68. printf("%lld\n",(ans+MOD)%MOD);
  69. return 0;
  70. }

【CJOJ2512】gcd之和(莫比乌斯反演)的更多相关文章

  1. 【BZOJ2820】YY的GCD(莫比乌斯反演)

    [BZOJ2820]YY的GCD(莫比乌斯反演) 题面 讨厌权限题!!!提供洛谷题面 题解 单次询问\(O(n)\)是做过的一模一样的题目 但是现在很显然不行了, 于是继续推 \[ans=\sum_{ ...

  2. 【BZOJ2818】Gcd(莫比乌斯反演)

    [BZOJ2818]Gcd(莫比乌斯反演) 题面 Description 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的 数对(x,y)有多少对. Input 一个整数N Ou ...

  3. 【HDU1695】GCD(莫比乌斯反演)

    [HDU1695]GCD(莫比乌斯反演) 题面 题目大意 求\(a<=x<=b,c<=y<=d\) 且\(gcd(x,y)=k\)的无序数对的个数 其中,你可以假定\(a=c= ...

  4. 【BZOJ2818】Gcd(莫比乌斯反演,欧拉函数)

    题意:给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对 1<=N<=10^7 思路:莫比乌斯反演,同BZOJ2820…… ; ..max]of ...

  5. 【51nod1678】lyk与gcd(莫比乌斯反演+枚举因数)

    点此看题面 大致题意: 一个长度为\(n\)的数组,实现两种操作:单点修改,给定\(i\)求\(\sum_{j=1}^na_j[gcd(i,j)=1]\). 莫比乌斯反演 考虑推一推询问操作的式子: ...

  6. hdu1695 GCD(莫比乌斯反演)

    题意:求(1,b)区间和(1,d)区间里面gcd(x, y) = k的数的对数(1<=x<=b , 1<= y <= d). 知识点: 莫比乌斯反演/*12*/ 线性筛求莫比乌 ...

  7. HDU 1695 GCD (莫比乌斯反演)

    GCD Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  8. acdream 1148 GCD SUM 莫比乌斯反演 ansx,ansy

    GCD SUM Time Limit: 8000/4000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) SubmitStatis ...

  9. spoj 7001. Visible Lattice Points GCD问题 莫比乌斯反演

    SPOJ Problem Set (classical) 7001. Visible Lattice Points Problem code: VLATTICE Consider a N*N*N la ...

  10. hdu_1695: GCD 【莫比乌斯反演】

    题目链接 这题求[1,n],[1,m]gcd为k的对数.而且没有顺序. 设F(n)为公约数为n的组数个数 f(n)为最大公约数为n的组数个数 然后在纸上手动验一下F(n)和f(n)的关系,直接套公式就 ...

随机推荐

  1. python中常见的三种句型if,while,for

    1.if语句: 特别说明:条件后面的冒号不能少,同样必须是英文字符. 特别特别说明:if内部的语句需要有一个统一的缩进,一般用4个空格.python用这种方法替代了其他很多编程语言中的{}. num= ...

  2. MAC下secretCRT使用技巧(转)

    1.打开secureCRT,按alt+b,可以调出快速启动栏,我相信secureCRT的忠实用户,都会保存一堆的sessions.2.按ctrl,可以同时选中多个session,再点击连接,可快速连接 ...

  3. 日程管理 FullCalendar

    日程管理,采用著名组件FullCalendar日历插件实现FullCalendar提供了丰富的属性设置和方法调用,开发者可以根据FullCalendar提供的API快速完成一个日历日程的开发1.实现按 ...

  4. eclipse 使 用Ctrl+鼠标左键进入mapper.xml文件的方法

    在 >eclipse MarketPlace中下载>Mybatipse 插件安装重启即可完成

  5. [译]Serilog Tutorial

    在过去的几年中,结构化日志已经大受欢迎.而Serilog是 .NET 中最著名的结构化日志类库 ,我们提供了这份的精简指南来帮助你快速了解并运用它. 0. 内容 设定目标 认识Serilog 事件和级 ...

  6. 02 浅析Spring的AOP(面向切面编程)

    1.关于AOP AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented Programming,面向对象编程)的补充和完善.O ...

  7. 内置函数--bin() oct() int() hex()

    英文文档: bin(x) Convert an integer number to a binary string. The result is a valid Python expression. ...

  8. python导入模块

    1.模块的定义: 模块定义:用来逻辑上组织python代码(变量.函数.类.逻辑:目的是:实现一个功能),本质就是.py结尾的python文件. 补充: 包的定义:用来从逻辑组织模块的,本质就是一个目 ...

  9. Git & github 使用指南

    Git的安装: 1.下载 Git for windows下载网址:https://git-for-windows.github.io/ 2.安装 选择安装路径: 选择组件:默认  是否修改环境变量 : ...

  10. java 集合框架(十五)Deque

    一.概述 Deque是Queue的子接口,我们知道Queue是一种队列形式,而Deque则是双向队列,它支持从两个端点方向检索和插入元素,因此Deque既可以支持LIFO形式也可以支持LIFO形式.D ...