题意

求$$\sum_1^n \sum_1^n \phi(gcd(i, j))$$

$T \leqslant 5000, N \leqslant 10^7$

Sol

延用BZOJ4407的做法

化到最后可以得到

$$\sum_{T = 1}^n \frac{n}{T} \frac{n}{T} \sum_{d \mid T}^n \phi(d) \mu(\frac{T}{d})$$

后面的那个是积性函数,直接筛出来

注意这个函数比较特殊,筛的时候需要分几种情况讨论

1. $H(p) = p - 2$

2. $H(p^2) = p^2 - 2p + 1$

3. $H(p^{k + 1}) = H(p^k) * p$

  1. // luogu-judger-enable-o2
  2. #include<cstdio>
  3. #include<algorithm>
  4. #define LL long long
  5. using namespace std;
  6. const int MAXN = 1e7 + , mod = 1e9 + ;
  7. inline int read() {
  8. char c = getchar(); int x = , f = ;
  9. while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
  10. while(c >= '' && c <= '') x = x * + c - '', c = getchar();
  11. return x * f;
  12. }
  13. int prime[MAXN], vis[MAXN], tot;
  14. LL H[MAXN], low[MAXN];
  15. void GetH(int N) {
  16. H[] = vis[] = ;
  17. for(int i = ; i <= N; i++) {
  18. if(!vis[i]) prime[++tot] = i, H[i] = i - , low[i] = i;
  19. for(int j = ; j <= tot && i * prime[j] <= N; j++) {
  20. vis[i * prime[j]] = ;
  21. if(!(i % prime[j])) {
  22. low[i * prime[j]] = low[i] * prime[j];
  23. if(low[i] == i) {
  24. if(low[i] == prime[j]) H[i * prime[j]] = (H[i] * prime[j] + );
  25. else H[i * prime[j]] = H[i] * prime[j];
  26. }
  27. else H[i * prime[j]] = H[i / low[i]] * H[low[i] * prime[j]];
  28. break;
  29. }
  30. H[i * prime[j]] = H[i] * H[prime[j]];
  31. low[i * prime[j]] = prime[j];
  32. }
  33. }
  34. for(int i = ; i <= N; i++)
  35. H[i] = H[i - ] + H[i];
  36. }
  37. int main() {
  38. GetH(1e7 + );
  39. int T = read();
  40. while(T--) {
  41. int N = read(), last;
  42. LL ans = ;
  43. for(int i = ; i <= N; i = last + ) {
  44. last = N / (N / i);
  45. ans = ans + 1ll * (N / i) * (N / i) * (H[last] - H[i - ]);
  46. }
  47. printf("%lld\n", ans);
  48. }
  49. return ;
  50. }
  51. /*
  52. 3
  53. 7001
  54. 123000
  55. 10000000
  56. */

BZOJ4804: 欧拉心算(莫比乌斯反演 线性筛)的更多相关文章

  1. 【BZOJ4804】欧拉心算 莫比乌斯反演+线性筛

    [BZOJ4804]欧拉心算 Description 给出一个数字N Input 第一行为一个正整数T,表示数据组数. 接下来T行为询问,每行包含一个正整数N. T<=5000,N<=10 ...

  2. 【bzoj4804】欧拉心算 莫比乌斯反演+莫比乌斯函数性质+线性筛

    Description 给出一个数字N 求\(\sum_{i=1}^{n}\sum_{j=1}^{n}\varphi(gcd(i,j))\) Input 第一行为一个正整数T,表示数据组数. 接下来T ...

  3. 【bzoj2693】jzptab 莫比乌斯反演+线性筛

    题目描述 输入 一个正整数T表示数据组数 接下来T行 每行两个正整数 表示N.M 输出 T行 每行一个整数 表示第i组数据的结果 样例输入 1 4 5 样例输出 122 题解 莫比乌斯反演+线性筛 由 ...

  4. 【bzoj2694】Lcm 莫比乌斯反演+线性筛

    题目描述 求$\sum\limits_{i=1}^n\sum\limits_{j=1}^m|\mu(gcd(i,j))|lcm(i,j)$,即$gcd(i,j)$不存在平方因子的$lcm(i,j)$之 ...

  5. 【bzoj4407】于神之怒加强版 莫比乌斯反演+线性筛

    题目描述 给下N,M,K.求 输入 输入有多组数据,输入数据的第一行两个正整数T,K,代表有T组数据,K的意义如上所示,下面第二行到第T+1行,每行为两个正整数N,M,其意义如上式所示. 输出 如题 ...

  6. BZOJ4804 欧拉心算(莫比乌斯反演+欧拉函数+线性筛)

    一通套路后得Σφ(d)μ(D/d)⌊n/D⌋2.显然整除分块,问题在于怎么快速计算φ和μ的狄利克雷卷积.积性函数的卷积还是积性函数,那么线性筛即可.因为μ(pc)=0 (c>=2),所以f(pc ...

  7. [BZOJ4804]欧拉心算:线性筛+莫比乌斯反演

    分析 关于这道题套路到不能再套路了没什么好说的,其实发这篇博客的目的只是为了贴一个线性筛的模板. 代码 #include <bits/stdc++.h> #define rin(i,a,b ...

  8. 中国剩余定理 & 欧拉函数 & 莫比乌斯反演 & 狄利克雷卷积 & 杜教筛

    ssplaysecond的博客(请使用VPN访问): 中国剩余定理: https://ssplaysecond.blogspot.jp/2017/04/blog-post_6.html 欧拉函数: h ...

  9. 51nod 1237 最大公约数之和 V3【欧拉函数||莫比乌斯反演+杜教筛】

    用mu写lcm那道卡常卡成狗(然而最后也没卡过去,于是写一下gcd冷静一下 首先推一下式子 \[ \sum_{i=1}^{n}\sum_{j=1}^{n}gcd(i,j) \] \[ \sum_{i= ...

随机推荐

  1. [原创] 详解云计算网络底层技术——虚拟网络设备 tap/tun 原理解析

    本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫. 在云计算时代, ...

  2. java并发编程知识点备忘

    最近有在回顾这方面的知识,稍微进行一些整理和归纳防止看了就忘记. 会随着进度不断更新内容,比较零散但尽量做的覆盖广一点. 如有错误烦请指正~ java线程状态图 线程活跃性问题 死锁 饥饿 活锁 饥饿 ...

  3. ASP.NET Core 2.1中基于角色的授权

    ASP.NET Core 2.1中基于角色的授权 授权是来描述用户能够做什么的过程.例如,只允许管理员用户可以在电脑上进行软件的安装以及卸载.而非管理员用户只能使用软件而不能进行软件的安装以及卸载.它 ...

  4. visual Studio 2017 扩展开发(三)《绑定快捷键到菜单项》

    如何将键盘快捷方式映射到自定义按钮,怎么使用快捷键启动自己创建的菜单,刚开始做的时候迷糊了,找了很久.可能也是因为刚开始做不是很明白,后面慢慢就懂了.其实非常简单的. 很多快捷键已经在Visual s ...

  5. while true 死循环判断端口按顺序启动应用

    需求:spring微服务应用启动较慢并且要求一个应用启完才能启第二个应用. 思路:加了个while true 死循环判断端口启动了才启下一个应用. 执行方式:/appupgrade/spring_cl ...

  6. 使用 pandas 导出数据

    import pandas as pd # In[58]: df = pd.DataFrame(houselist) # In[59]: df # In[61]: df.to_csv('lianjia ...

  7. 使用google wire解决依赖注入

    使用google wire解决依赖注入 google wire是golang的一个依赖注入解决的工具,这个工具能够自动生成类的依赖关系. 当我们写代码的时候,都希望,类都是一个个独立的结构,互不耦合, ...

  8. bash 的配置文件加载顺序

    bash配置文件的加载顺序和登陆方式有关,下面先介绍下登陆方式. 1 登陆方式有2种 登陆式SHELL: su - oracle    su -l oracle 正常从终端登陆 非登录式SHELL: ...

  9. 视频人脸检测——Dlib版(六)

    往期目录 视频人脸检测--Dlib版(六) OpenCV添加中文(五) 图片人脸检测--Dlib版(四) 视频人脸检测--OpenCV版(三) 图片人脸检测--OpenCV版(二) OpenCV环境搭 ...

  10. 第7章 Linux上配置RAID

    7.1 RAID概念 RAID独立磁盘冗余阵列(Redundant Array of Independent Disks),RAID技术是将许多块硬盘设备组合成一个容量更大.更安全的硬盘组,可以将数据 ...