博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Problem I. Count - HDU - 6434(欧拉函数)
阅读量:5268 次
发布时间:2019-06-14

本文共 1930 字,大约阅读时间需要 6 分钟。

题意

给一个\(n\),计算

\[\sum_{i=1}^{n}\sum_{j=1}^{i-1}[gcd(i + j, i - j) = 1]\]

题解

\(a = i - j\)

要求

\[\sum_{i=1}^{n}\sum_{j=1}^{i-1}[gcd(i + j, i - j) = 1]\]
即求
\[\sum_{i=1}^{n}\sum_{a=1}^{i-1}[gcd(2*i - a, a) = 1]\]

根据\(gcd\)的性质,即

\[\sum_{i=1}^{n}\sum_{a=1}^{i-1}[gcd(2*i, a) = 1]\]

所以要求的就是\(1\)\(i-1\)中,与\(2*i\)互质的数的个数。

\(sum[i]\)\(i\)的欧拉函数\(\phi\)的前缀和。结论是,对于奇数,答案就是\(sum[i]/2\),对于偶数,答案是\(sum[i]\)

\(2*i\)互质的数的个数,和\(\phi(i)\)(与\(i\)互质的数的个数)有什么关系呢?

如果\(i\)是奇数,那么\(1\)\(i-1\)中与\(i\)互质的所有数中的奇数,都与\(2*i\)互质。

如果\(i\)是偶数,那么\(1\)\(i-1\)中与\(i\)互质的所有数,都与\(2*i\)互质。

现在的问题是,为什么\(1\)\(i-1\)中,与\(i\)互质的数中,奇数占一半?

因为对于任何一个奇数,小于它的和它互质的数,是以\(k\)\(n-k\)的形式成对出现的。这两个数必然一奇一偶。

代码

#include 
#include
#include
#include
#include
#define FOPI freopen("in.txt", "r", stdin)#define FOPO freopen("out.txt", "w", stdout)using namespace std;typedef long long LL;const int maxn = 2e7 + 5;int phi[maxn], prime[maxn];LL sum[maxn];int tot = 0;void getPhi(int n){ for (int i = 2; i <= n; i++) phi[i] = 0; phi[1] = 1; for (int i = 2; i <= n; i++) { if (!prime[i]) { prime[++tot] = i; phi[i] = i-1; } for (int j = 1; j <= tot; j++) { if (i*prime[j] > n) break; prime[i*prime[j]] = 1; if (i % prime[j] == 0) { phi[i*prime[j]] = prime[j] * phi[i]; break; } else phi[i*prime[j]] = (prime[j]-1)*phi[i]; } }}void init(int n){ getPhi(n); for (int i = 1; i <= n; i++) if (i % 2 == 1) sum[i] = sum[i-1] + phi[i] / 2; else sum[i] = sum[i-1] + phi[i];}int t, n;int main(){ init(2e7); scanf("%d", &t); for (int ca = 1; ca <= t; ca++) { scanf("%d", &n); printf("%lld\n", sum[n]); }}

转载于:https://www.cnblogs.com/ruthank/p/10910449.html

你可能感兴趣的文章
java笔记——引用类型
查看>>
Karma 4 - Karma 集成 Webpack 进行单元测试
查看>>
第五周作业
查看>>
Translation of good sentences
查看>>
Java 中的 static 使用之静态初始化块
查看>>
linux压缩解压
查看>>
在网页上点击图片显示大图
查看>>
Magento控制器
查看>>
启用yarn日志聚集功能
查看>>
iOS 阶段学习第四天笔记(循环)
查看>>
Hibernate 多对多
查看>>
Nebula3 Light && Shadow 系统
查看>>
CSS_绝对定位偏移
查看>>
java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener
查看>>
T-SQL查询进阶--深入浅出视图
查看>>
[.NET Core 24]把project.json迁移到.csproj
查看>>
卸载、指定卸载 .NET Core Runtime and SDK
查看>>
Django - 获取请求方式
查看>>
子网掩码
查看>>
相对导入与绝对导入
查看>>