Crash的数字表格

Description

今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple)。对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数。例如,LCM(6, 8) = 24。回到家后,Crash还在想着课上学的东西,为了研究最小公倍数,他画了一张N*M的表格。每个格子里写了一个数字,其中第i行第j列的那个格子里写着数为LCM(i, j)。一个4*5的表格如下: 1 2 3 4 5 2 2 6 4 10 3 6 3 12 15 4 4 12 4 20 看着这个表格,Crash想到了很多可以思考的问题。不过他最想解决的问题却是一个十分简单的问题:这个表格中所有数的和是多少。当N和M很大时,Crash就束手无策了,因此他找到了聪明的你用程序帮他解决这个问题。由于最终结果可能会很大,Crash只想知道表格里所有数的和mod 20101009的值。

Input

输入的第一行包含两个正整数,分别表示N和M。

Output

输出一个正整数,表示表格中所有数的和mod 20101009的值。

Sample Input

4 5

Sample Output

122

数据规模和约定

100%的数据满足N, M ≤ 10^7。

题解

我们不妨设 N < M ,这样好做些

很容易就可以得出,我们想要的答案是

枚举lcm不方便,我们用gcd

我们枚举gcd,上式就等于

我们把d分之一右边的式子拿出来处理,设

我们发现这个不好求,我们先求一个比较容易的,设

我们发现右边括号里的就是 ,可以用等差数列求和公式直接套,那么

由于我们发现F(n)和f(n)有这样的关系:

那么用一下莫比乌斯反演:

我们把它代入前面的ans:

然后我们求d和的前缀和,再分块就行。

这里可能很多人不理解这个分块是什么(我刚看题解的时候也不知道),我就解释一下

由于xd在一定的区间 [l , r] 中波动时, 的值是不变的,所以我们每次就直接算这个区间,中间不变,旁边的求d和的前缀和就可以解决,这样可以大大减少时间复杂度,两重循环下来就是O(n)了。

CODE

zxy AK了,%%%%%%%%

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<vector>
  4. #include<stack>
  5. #include<queue>
  6. #include<algorithm>
  7. #include<map>
  8. #include<cmath>
  9. #include<iostream>
  10. #define MAXN 10000005
  11. #define LL long long
  12. #define rg register
  13. #define lowbit(x) (-(x) & (x))
  14. #define ENDL putchar('\n')
  15. //#pragma GCC optimize(2)
  16. //#pragma G++ optimize(3)
  17. //#define int LL
  18. using namespace std;
  19. inline int read() {
  20. int f = 1,x = 0;char s = getchar();
  21. while(s < '0' || s > '9') {if(s == '-')f = -1;s = getchar();}
  22. while(s >= '0' && s <= '9') {x = x * 10 - '0' + s;s = getchar();}
  23. return x * f;
  24. }
  25. int zxy = 20101009;
  26. int n,m,i,j,k,s,o;
  27. int p[MAXN],cnt,mu[MAXN];
  28. bool f[MAXN];
  29. void sieve(int n) {
  30. mu[1] = 1;
  31. for(int i = 2;i <= n;i ++) {
  32. if(!f[i]) {
  33. p[++ cnt] = i;
  34. mu[i] = -1;
  35. }
  36. for(int j = 1;j <= cnt && i * p[j] <= n;j ++) {
  37. f[i * p[j]] = 1;
  38. if(i % p[j] == 0) {
  39. mu[i * p[j]] = 0;
  40. break;
  41. }
  42. else mu[i * p[j]] = -mu[i];
  43. }
  44. }
  45. for(int i = 1;i <= n;i ++) mu[i] = ((LL)mu[i] * i % zxy * i + mu[i-1]) % zxy;
  46. return ;
  47. }
  48. inline int dx(int a,int b) {
  49. return 1ll*(a + b) * (b - a + 1) / 2ll % zxy;
  50. }
  51. int solve(int n,int m) {
  52. LL ans = 0,ans2 = 0;int ii,jj;
  53. for(int i = 1;i <= n;i = ii + 1) {
  54. ii = min(n / (n / i),m / (m / i));
  55. int nd = n / i,md = m / i; ans2 = 0;
  56. for(int j = 1;j <= nd;j = jj + 1) {
  57. jj = min(nd / (nd / j),md / (md / j));
  58. ans2 = (ans2 + (0ll+mu[jj] - mu[j-1]) * dx(1,nd/j) % zxy * dx(1,md/j) % zxy) % zxy;
  59. }
  60. ans = (ans + 1ll * ans2 * dx(i,ii) % zxy) % zxy;
  61. }
  62. return (ans + zxy) % zxy;
  63. }
  64. signed main() {
  65. n = read();m = read();
  66. if(n > m) swap(n,m);
  67. sieve(m);
  68. printf("%d",solve(n,m));
  69. return 0;
  70. }

Crash的数字表格 (莫比乌斯反演)的更多相关文章

  1. [BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块)

    [BZOJ 2154]Crash的数字表格(莫比乌斯反演+数论分块) 题面 求 \[\sum_{i=1}^{n} \sum_{j=1}^{m} \mathrm{lcm}(i,j)\] 分析 \[\su ...

  2. BZOJ 2154: Crash的数字表格 [莫比乌斯反演]

    2154: Crash的数字表格 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 2924  Solved: 1091[Submit][Status][ ...

  3. [bzoj 2693] jzptab & [bzoj 2154] Crash的数字表格 (莫比乌斯反演)

    题目描述 TTT组数据,给出NNN,MMM,求∑x=1N∑y=1Mlim(x,y)\sum_{x=1}^N\sum_{y=1}^M lim(x,y)\newlinex=1∑N​y=1∑M​lim(x, ...

  4. 【bzoj2154】Crash的数字表格 莫比乌斯反演

    题目描述 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数.例如,LCM(6, ...

  5. 【BZOJ】2154: Crash的数字表格 莫比乌斯反演

    [题意]给定n,m,求Σlcm(i,j),1<=i<=n,1<=j<=m,n,m<=10^7. [算法]数论(莫比乌斯反演) [题解] $$ans=\sum_{i\leq ...

  6. BZOJ 2154 Crash的数字表格 ——莫比乌斯反演

    求$\sum_{i=1}^n\sum_{j=1}^n lcm(i,j)$ 枚举因数 $ans=\sum_{d<=n} F(d) * d$ $F(d)$表示给定范围内两两$\sum_{gcd(i, ...

  7. [国家集训队] Crash的数字表格 - 莫比乌斯反演,整除分块

    考虑到\(lcm(i,j)=\frac{ij}{gcd(i,j)}\) \(\sum_{i=1}^n\sum_{j=1}^m\frac{ij}{gcd(i,j)}\) \(\sum_{d=1}^{n} ...

  8. bzoj2154: Crash的数字表格 莫比乌斯反演

    题意:求\(\sum_{i=1}^n \sum_{j=1}^m\frac{i*j}{gcd(i,j)}\) 题解:\(ans=\sum_{i=1}^n\sum_{j=1}^m \frac{i*j}{g ...

  9. 洛谷 - P1829 - Crash的数字表格 - 莫比乌斯反演

    求: \(S(n,m)=\sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}lcm(i,j)\) 显然: \(S(n,m)=\sum\limits_{i=1}^{n}\ ...

  10. 【BZOJ4816】【SDOI2017】数字表格 [莫比乌斯反演]

    数字表格 Time Limit: 50 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description Doris刚刚学习了fibonac ...

随机推荐

  1. docker引起服务器磁盘爆满

    服务器异常 又是开开心心打开我心爱的服务器一天: 吔!这是嘛啊?我的服务器域名访问不了了,一直转圈圈超时了,好,打开ssh远程看看,吔!!!还是访问不了,宕机了?怀着一颗憋大便的心情打开了阿里云控制面 ...

  2. 互联网公司目标管理OKR和绩效考核的误区

    最近看了一篇关于「谷歌放弃OKR,转向全新的GRAD系统」的文章,我转到了研发效能DevOps的微信群里,结果引起了大家热烈的讨论,正好我们也在使用 OKR,所以也来谈谈我的理解以及我们应用起来的实际 ...

  3. JAVA面向对象之封装和调用

    一   面向对象 面向对象的三大特性   1 封装:概念:封装是把过程和数据私有化,打包封存起来,对数据访问只能通过指定的方式.简单的可以理解为你把钱存到银行里,银行专员首先要给你开一个账户,之后你的 ...

  4. 智慧机房3D可视化技术解决方案

    随着夏季气温越来越高,机房内大量设备同步工作时,难免使机房内温度飙升. 机房温度每升高10℃,计算机的可靠性就下降25% 磁盘磁带也会因热涨效应造成记录错误 计算机的时钟主频在温度过高都会降低 UPS ...

  5. 关于vue项目中axios跨域的解决方法(开发环境)

    1.在config文件中修改index.js proxyTable: { "/api":{ target: 'https://www.baidu.com/muc/',//你需要跨域 ...

  6. 你真的懂Python命名吗?

    转载请注明出处️ 作者:测试蔡坨坨 原文链接:caituotuo.top/7417a7f0.html 大家好,我是测试蔡坨坨. 今天,我们来聊一下Python命名那些事儿. 名为万物之始,万物始于无名 ...

  7. 从Hadder看蛋白质分子中的加氢算法

    技术背景 PDB(Protein Data Bank)是一种最常用于存储蛋白质结构的文件.而我们在研究蛋白质构象时,往往更多的是考虑其骨架,因此在很多pdb文件中直接去掉了氢原子.但是在我们构建蛋白质 ...

  8. 查询效率提升10倍!3种优化方案,帮你解决MySQL深分页问题

    开发经常遇到分页查询的需求,但是当翻页过多的时候,就会产生深分页,导致查询效率急剧下降. 有没有什么办法,能解决深分页的问题呢? 本文总结了三种优化方案,查询效率直接提升10倍,一起学习一下. 1. ...

  9. Python图像处理丨三种实现图像形态学转化运算模式

    摘要:本篇文章主要讲解Python调用OpenCV实现图像形态学转化,包括图像开运算.图像闭运算和梯度运算 本文分享自华为云社区<[Python图像处理] 九.形态学之图像开运算.闭运算.梯度运 ...

  10. c++小游戏--五子棋

    大家好,我是芝麻狐! 这是我自制的小游戏,目前仅支持devc++. 如果你没有c++软件, 请打开网站GDB online Debugger | Compiler - Code, Compile, R ...