[51 nod 123] 最大公约数之和 V3(杜教筛)

1237 最大公约数之和 V3

推式子

∑i=1n∑j=1ngcd(i,j)=∑d=1nd∑i=1n∑j=1n(gcd(i,j)==d)=∑d=1nd∑i=1nd∑j=1nd(gcd(i,j)==1)=∑d=1nd∑i=1nd∑j=1nd∑k∣gcd(i,j)μ(k)=∑d=1nd∑k=1ndμ(k)∑i=1nkd∑j=1nkd1套路地设t=kd=∑t=1n(⌊nt⌋)2∑d∣tdμ(td)=∑t=1n(⌊nt⌋)2ϕ(t)接下来就是杜教筛求∑i=1nϕ(i)了,那这不就是杜教筛水题了嘛。\sum_{i = 1} ^{n} \sum_{j = 1} ^{n} gcd(i, j)\\ = \sum_{d = 1} ^{n} d\sum_{i = 1} ^ {n} \sum_{j = 1} ^ {n} (gcd(i, j) == d)\\ = \sum_{d = 1} ^{n} d\sum_{i = 1} ^{\frac{n}{d}} \sum_{j = 1} ^{\frac{n}{d}}(gcd(i, j) == 1)\\ = \sum_{d = 1} ^{n} d\sum_{i = 1} ^{\frac{n}{d}} \sum_{j = 1} ^{\frac{n}{d}} \sum_{k \mid gcd(i, j)} \mu(k)\\ = \sum_{d = 1} ^{n} d\sum_{k = 1} ^{\frac{n}{d}} \mu(k) \sum_{i = 1} ^{\frac{n}{kd}} \sum_{j = 1} ^{\frac{n}{kd}}1\\ 套路地设t = kd\\ =\sum_{t = 1} ^{n} \left(\lfloor\frac{n}{t}\rfloor \right) ^ 2 \sum_{d \mid t} d \mu(\frac{t}{d})\\ =\sum_{t = 1} ^{n} \left(\lfloor\frac{n}{t}\rfloor \right) ^ 2 \phi(t)\\ 接下来就是杜教筛求\sum_{i = 1} ^{n} \phi(i)了,那这不就是杜教筛水题了嘛。 i=1nj=1ngcd(i,j)=d=1ndi=1nj=1n(gcd(i,j)==d)=d=1ndi=1dnj=1dn(gcd(i,j)==1)=d=1ndi=1dnj=1dnkgcd(i,j)μ(k)=d=1ndk=1dnμ(k)i=1kdnj=1kdn1t=kd=t=1n(tn)2dtdμ(dt)=t=1n(tn)2ϕ(t)i=1nϕ(i)

代码

/*Author : lifehappy
*/
#pragma GCC optimize(2)
#pragma GCC optimize(3)
#include <bits/stdc++.h>#define mp make_pair
#define pb push_back
#define endl '\n'
#define mid (l + r >> 1)
#define lson rt << 1, l, mid
#define rson rt << 1 | 1, mid + 1, r
#define ls rt << 1
#define rs rt << 1 | 1using namespace std;typedef long long ll;
typedef unsigned long long ull;
typedef pair<int, int> pii;const double pi = acos(-1.0);
const double eps = 1e-7;
const int inf = 0x3f3f3f3f;inline ll read() {ll f = 1, x = 0;char c = getchar();while(c < '0' || c > '9') {if(c == '-')    f = -1;c = getchar();}while(c >= '0' && c <= '9') {x = (x << 1) + (x << 3) + (c ^ 48);c = getchar();}return f * x;
}const int N = 8e6 + 10, mod = 1000000007;ll phi[N], inv2;int prime[N], cnt;bool st[N];ll quick_pow(ll a, ll n, ll mod) {ll ans = 1;while(n) {if(n & 1) ans = ans * a % mod;a = a * a % mod;n >>= 1;}return ans;
}void init() {phi[1] = 1;for(int i = 2; i < N; i++) {if(!st[i]) {prime[cnt++] = i;phi[i] = i - 1;}for(int j = 0; j < cnt && 1ll * i * prime[j] < N; j++) {st[i * prime[j]] = 1;if(i % prime[j] == 0) {phi[i * prime[j]] = phi[i] * prime[j];break;}phi[i * prime[j]] = phi[i] * (prime[j] - 1);}}for(int i = 1; i < N; i++) {phi[i] = (phi[i - 1] + phi[i]) % mod;}inv2 = quick_pow(2, mod - 2, mod);
}ll calc(ll x) {x %= mod;return x * (x + 1) % mod * inv2 % mod;
}map<ll, ll> ans_phi;ll get_phi(ll x) {if(x < N) return phi[x];if(ans_phi.count(x)) return ans_phi[x];ll ans = calc(x);for(ll l = 2, r; l <= x; l = r + 1) {r = x / (x / l);ans = (ans - (r - l + 1) % mod * get_phi(x / l) % mod + mod) % mod;}return ans_phi[x] = ans;
}ll calc2(ll x) {x %= mod;return x * x % mod;
}int main() {// freopen("in.txt", "r", stdin);// freopen("out.txt", "w", stdout);// ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);ll n = read(), ans = 0;init();for(ll l = 1, r; l <= n; l = r + 1) {r = n / (n / l);ans = (ans + calc2(n / l) * (get_phi(r) - get_phi(l - 1)) % mod + mod) % mod;}cout << ans << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314357.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用WebDeploy部署远程IIS网站

目录 使用WebDeploy部署远程IIS网站后台服务部署服务器配置本地WebDeploy发布文件配置前端页面部署WebDeploy服务端配置WebDeploy发布文件配置使用WebDeploy部署远程网站后台服务部署服务器配置打开IIS管理器(开始->控制面板->管理工具->IIS管理器)添加网站(右键网站…

数列分块入门

文章目录数列分块入门1数列分块入门2数列分块入门3数列分块入门4数列分块入门5数列分块入门6数列分块入门7数列分块入门8数列分块入门9数列分块入门1 区间加&#xff0c;单点查询 分块后&#xff0c;维护标记&#xff0c;零散块暴力加&#xff0c;查询时输出值加标记 数列分块…

CF436F Banners(分块/凸包/单调队列)

CF436F Banners 首先有n个物品分别有ai和bi&#xff0c;然后定义价值为 c∗wp∗(ai大于p且bi小于c的用户个数)c*wp*(ai大于p且bi小于c的用户个数)c∗wp∗(ai大于p且bi小于c的用户个数) 然后我们需要求解对于每一个c的最大价值和对应的p 首先我们先枚举c&#xff0c;然后每次加…

译 | 改进 Visual Studio 及 Windows 上 .NET Core 的安装体验

点击上方蓝字关注“汪宇杰博客”原文&#xff1a;Lee Coward翻译&#xff1a;Edi Wang导语Visual Studio 2019 16.3 和 .NET Core 3.0 Preview 7 改进了 Windows 上 .NET Core 的安装体验。目标是减少计算机上可能存在的 .NET Core 版本的数量。这些改进基于客户反馈和我们自己…

F. Ivan and Burgers(前缀线性基模板)

前缀线性基模板 F. Ivan and Burgers /*Author : lifehappy */ #pragma GCC optimize(2) #pragma GCC optimize(3) #include <bits/stdc.h>#define mp make_pair #define pb push_back #define endl \n #define mid (l r >> 1) #define lson rt << 1, l, …

P2231 [HNOI2002]跳蚤(裴蜀定理/莫比乌斯反演)

P2231 [HNOI2002]跳蚤 给定一个长度为n1的一列数&#xff0c;第n1位为m&#xff0c;前n位小于m 求解使得他n1个数的加减可以凑出1的方案数 首先可以凑出1&#xff0c;这显然是裴蜀定理&#xff0c;推一推就发现他要求所有数的gcd为1 那么对于要求gcd恰为x的计数问题&#xff…

HDU 6579 Operation (前缀线性基模板题)

Operation 思路 只要套上前缀线性基的板子然后按照题意模拟即可&#xff0c;前缀线性基模板题了。 代码 /*Author : lifehappy */ #pragma GCC optimize(2) #pragma GCC optimize(3) #include <bits/stdc.h>#define mp make_pair #define pb push_back #define endl …

SonarQube系列三、Jenkins集成SonarQube(dotnetcore篇)

来源&#xff1a;https://www.cnblogs.com/7tiny/p/11348785.html【前言】本系列主要讲述sonarqube的安装部署以及如何集成jenkins自动化分析.netcore项目。目录如下&#xff1a;SonarQube系列一、Linux安装与部署SonarQube系列二、分析dotnet core/C#代码SonarQube系列三、Jen…

[2020多校A层11.22]party(概率期望/近似)

[2020多校A层11.22]party 非常巧妙的一个概率期望问题&#xff0c;其实运用的还是近似的思想 现在有n个物品&#xff0c;每次一个人有pi的概率选中这个物品&#xff0c;然后可以进行猜测&#xff0c;但是无论是否猜中都继续游戏&#xff0c;直到所有人都被猜中&#xff0c;求解…

E. Beautiful Subarrays(思维 01 trie 树)

E. Beautiful Subarrays 思路 显然有ai⨁ai1⨁……⨁an(a1⨁a2⨁……⨁an)⨁(a1⨁a2⨁……⨁ai−1)a_i\bigoplus a_{i 1} \bigoplus ……\bigoplus a_{n} (a_1 \bigoplus a_2 \bigoplus……\bigoplus a_{n}) \bigoplus (a_1 \bigoplus a_2 \bigoplus …… \bigoplus a_{i -…

CF198D Cube Snake(三维空间/增量构造)

CF198D Cube Snake n<50 显然是一个构造题&#xff0c;然后很容易想到增量构造&#xff0c;可以考虑每次保证一层值域连续&#xff0c;然后再增加一个值域连续的层&#xff0c;就会产生两个值域连续的正方体&#xff0c;但是只移动头是不够的&#xff0c;所以我们还需要移…

发布ABP v0.19包含Angular UI选项

ABP v0.19已发布,包含解决的~90个问题和600次提交.新功能Angular UI终于,ABP有了一个SPA UI选项,使用最新的Angular框架.Angular的集成不是简单地创建了一个启动模板.创建了一个基础架构来处理ABP的模块化,主题和其他一些功能.此基础结构已部署为NPM包.为帐户,身份和租户管理等…

P4151 [WC2011]最大XOR和路径(线性基应用)

P4151 [WC2011]最大XOR和路径 思路 如果单纯的只是树形图&#xff0c;那么答案显然易见只有一种&#xff0c;也就是从头到尾的路径从头到尾的异或值&#xff0c;但是这里不同的就是有可能在道路上有许多的环。 题目有一个重点提示的一句话 理解这句话之后那么我们可以显然…

CF603D Ruminations on Ruminants(计算几何/Simson theorem)

CF603D Ruminations on Ruminants 给定n条直线&#xff0c;两两不平行&#xff0c;且任意三条直线不经过同一个点&#xff0c;然后求解满足原点在外接圆上的由三条直线围成的三角形有多少个。 首先这道题只需要知道Simson theorem就可以做了。 定理内容是三角形外接圆上的点到…

Docker(一)-CentOS7中安装Docker视频教程

一、前言Docker的使用越来越多&#xff0c;安装也相对简单。本文使用视频的方式展示在CentOS7系统中安装Docker&#xff0c;本文更适合于准备入门学习Docker的童靴&#xff0c;同时也欢迎各路大神给我们指点提建议。二、环境CentOS7三、安装Docker确认Linux内核版本# uname -a卸…

P3292 [SCOI2016]幸运数字(树剖 + 线段树维护线性基)

P3292 [SCOI2016]幸运数字 思路 如果这题是求x,yx, yx,y之间的距离显然我们可以通过树剖加线段树来写&#xff0c; 但是这里变成了求任意个数的异或最大值。如果给定区间我们显然可以通过线性基来求解&#xff0c;但是这里是动态的区间&#xff0c;每次区间需要我们去找&…

CF773E Blog Post Rating(推导min的通项/线段树)

CF773E Blog Post Rating 现在有一个值F&#xff0c;每次如果序列加入一个数后重新排列&#xff0c;每次如果F小于期望值&#xff0c;就会1&#xff0c;如果等于就不变&#xff0c;如果大于就-1&#xff0c;求解每一次加入后F的最大值。 这道题的确是非常的巧妙&#xff0c;尤…

用Keras.NET 做一个图像识别的训练

.NET Core 的应用场景越来越广&#xff0c;开源社区也不断壮大&#xff0c; .NET Core在机器学习领域不断发展ML.NET外&#xff0c;也通过结合Tensorflow.NET去完善ML.NET在深度学习领域的功能&#xff0c;在ML.NET 1.3开始迈出了非常重要的一步。这不仅是微软拥抱开源的策略&a…

2019牛客多校第四场 B xor (线性基求交)

xor 思路 题目是要求[l,r][l, r][l,r]的所有集合是否都可以得到xxx&#xff0c;那么显然我们可以对这[l,r][l, r][l,r]个线性基求交&#xff0c;然后再特判能否xxx能否插入&#xff0c;如果能插入&#xff0c;显然输出NONONO&#xff0c;否则就输出YESYESYES&#xff0c;所以…

「数据ETL」从数据民工到数据白领蜕变之旅(六)-将Python的能力嫁接到SSIS中...

前一篇推文中&#xff0c;给大家演示了在SSIS上使用dotNET脚本&#xff0c;实现一些原生SSIS难以实现的功能&#xff0c;并冠以无限可能的说法。充分复用python的现有优势python的确是一门非常优秀的编程语言&#xff0c;特别是在数据领域&#xff0c;网络爬虫、数据处理、分析…