LJJ爱数数
求\(\sum_{i=1}^n\sum_{j=1}^n\sum_{k=1}^n\epsilon(gcd(i,j,k))(\frac{1}{i}+\frac{1}{j}==\frac{1}{k}),n\leq 10^{12}\)
解
显然无法用Mobius反演,问题在于\(\frac{1}{i}+\frac{1}{j}==\frac{1}{k}\),要将其转换为gcd条件。
法一:先约数拆分,再证明对应相等
分数我们无法处理,所以有
\]
设\(g=gcd(i,j),I=i/g,J=j/g\),接着有
\]
\]
考虑分数反证,设
\]
\(if(d>1)\)
\]
而
\]
所以与原命题矛盾,故\(d=1\),因此\(I+J=g,IJ=k,gcd(g,I)=1\),满足了等式,也满足了\(gcd(g,k)=1\),所以自然枚举g,再枚举I,以此k也就确定了,接下来问题在于范围,显然要回到\(i,j,k\)
\]
现在考虑\(I\)
\]
\]
于是总上,设\(L(g),R(g)\)为在g意义下\(I\)的范围,有
\]
注意到后式取值范围受到g的影响,所以对后式单独维护
设
\]
\]
由Mobius反演定理,我们有
\]
因此
\]
所以
\]
\]
显然后式可以暴力算,时间复杂度应为\(O(\sqrt{n}log(\sqrt{n}))\)。
参考代码:
#include <iostream>
#include <cstdio>
#include <cmath>
#define il inline
#define ri register
#define ll long long
using namespace std;
bool check[2000000];
int prime[150000],pt,mu[2000000],
R[2000000],L[2000000];
il void prepare(int);
template<class free>il free Min(free,free);
template<class free>il free Max(free,free);
int main(){
ll n,sn,i,j,ans(0);
scanf("%lld",&n),sn=sqrt(n<<1),prepare(sn);
for(i=1;i<=sn;++i)L[i]=Max(i-n/i,1ll),
R[i]=Min(i-1,n/i);
for(i=1;i<=sn;++i)
for(j=i;j<=sn;j+=i)
ans+=mu[i]*(R[j]/i-(L[j]-1)/i);
printf("%lld",ans);
return 0;
}
il void prepare(int n){
int i,j;check[1]|=mu[1]|=true;
for(i=2;i<=n;++i){
if(!check[i])prime[++pt]=i,mu[i]=-1;
for(j=1;j<=pt&&i*prime[j]<=n;++j){
check[i*prime[j]]|=true;
if(!(i%prime[j]))break;
mu[i*prime[j]]=~mu[i]+1;
}
}
}
template<class free>il free Max(free a,free b){return a>b?a:b;}
template<class free>il free Min(free a,free b){return a<b?a:b;}
法二:先证明对应相等再约数拆分
注意到\(ik+jk=ij\),类似因式分解形式,于是添项因式分解,
\]
\]
\]
再进行约数拆分
\]
\]
\]
\]
\]
故充分条件为\(j-k=n^2,i-k=m^2,gcd(m,n)=1\),故考虑枚举n,m,为了与题目数据范围的n区分,把数据范围的n改为N,现在关键在于找数据范围,回到i,j,首先显然\(m\in[1,\sqrt{N}]\)
\]
\]
但事实上,我们只能枚举整数,但是m,n有可能为无理数,但是我们可以证明这样没有影响
设\(m=\sqrt{x},n=\sqrt{y}(x,y\in Z)\),于是有\(i=\sqrt{xy}+x,j=\sqrt{xy}+y,k=\sqrt{xy}\)
但是因为\(i,j\in Z\),所以必然存在一个\(z\in Z\),满足\(xy=z^2\),容易知道x,y,z两两不互质,所以有
\(i=x+z,j=y+z,k=z\),容易知道\(i,j,k\)不互质,那么与题设矛盾,于是不可能。
设其范围为\(r(m)\),于是有
\]
同法一,后式是变的,维护后式,设
\]
\]
由Mobius反演定理,我们有
\]
\]
代入原式即
\]
显然后式处理平均只要\(log(\sqrt(N))\),所以时间复杂度应为\(\sqrt{N}log(\sqrt{N})\)。
参考代码:
#include <iostream>
#include <cstdio>
#include <cmath>
#define il inline
#define ri register
#define ll long long
using namespace std;
bool check[1000001];
int prime[100001],pt,mu[1000001],
li[1000001];
il void prepare(int);
template<class free>
il free Min(free,free);
int main(){
ll n,ans(0),sn,i,j;
scanf("%lld",&n),sn=sqrt(n),prepare(sn);
for(i=1;i<=sn;++i)li[i]=Min((n-i*i)/i,(ll)(sqrt(i*i+4*n)-i)/2);
for(i=1;i<=sn;++i)
for(j=i;j<=sn;j+=i)
ans+=mu[i]*(li[j]/i);
printf("%lld",ans);
return 0;
}
template<class free>
il free Min(free x,free y){
return x<y?x:y;
}
il void prepare(int n){
int i,j;check[1]|=mu[1]|=true;
for(i=2;i<=n;++i){
if(!check[i])prime[++pt]=i,mu[i]=-1;
for(j=1;j<=pt&&i*prime[j]<=n;++j){
check[i*prime[j]]|=true;
if(!(i%prime[j]))break;
mu[i*prime[j]]=~mu[i]+1;
}
}
}
LJJ爱数数的更多相关文章
- 「LOJ6482」LJJ爱数数
「LOJ6482」LJJ爱数数 解题思路 : 打表发现两个数 \(a, b\) 合法的充要条件是(我不管,我就是打表过的): \[ a + b = \text{gcd}(a, b)^2 \] 设 \( ...
- P4844 LJJ爱数数
题目 P4844 LJJ爱数数 本想找到莫比乌斯反演水题练练,结果直接用了两个多小时才做完 做法 \(\sum\limits_{a=1}^n\sum\limits_{b=1}^n\sum\limits ...
- P4844 LJJ爱数数 数论
思路: 化简后得到(a+b)c=ab,设g=(a,b),A=a/g,B=b/g,则g(A+B)c=ABg^2,即(A+B)c=ABg 由题目已知条件:(a,b,c)=1,即(g,c)=1,g|(A+B ...
- [HZOI 2016]我们爱数数
[HZOI 2016]我们爱数数 题目大意: 一张圆桌,每个位置按顺时针从\(1\)到\(n\)编号.有\(n\)个人,编号从\(1\)到\(n\).如果编号为\(i\)的人坐到了编号为\(i\)的位 ...
- COJ 0036 数数happy有多少个?
数数happy有多少个? 难度级别:B: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 图图是个爱动脑子.观察能力很强的好学生.近期他正学英语 ...
- 【BZOJ】【3530】【SDOI2014】数数
AC自动机/数位DP orz zyf 好题啊= =同时加深了我对AC自动机(这个应该可以叫Trie图了吧……出边补全!)和数位DP的理解……不过不能自己写出来还真是弱…… /************* ...
- BZOJ3530: [Sdoi2014]数数
3530: [Sdoi2014]数数 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 322 Solved: 188[Submit][Status] ...
- 【HDU3530】 [Sdoi2014]数数 (AC自动机+数位DP)
3530: [Sdoi2014]数数 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 682 Solved: 364 Description 我们称一 ...
- BZOJ 3530: [Sdoi2014]数数 [AC自动机 数位DP]
3530: [Sdoi2014]数数 题意:\(\le N\)的不含模式串的数字有多少个,\(n=|N| \le 1200\) 考虑数位DP 对于长度\(\le n\)的,普通套路DP\(g[i][j ...
随机推荐
- word2vec中关于霍夫曼树的
再谈word2vec 标签: word2vec自然语言处理NLP深度学习语言模型 2014-05-28 17:17 16937人阅读 评论(7) 收藏 举报 分类: Felven在职场(86) ...
- bash数组总结
bash数组操作 bash支持两种数组,一种是索引数组,一种是关联数组 索引数组 数组的值类型是任意的,索引也未必一定要连续,当做列表理解更好 下面总结下索引数组,即列表: 1. 声明 declare ...
- day26-多态、封装、反射
#!/usr/bin/env python # -*- coding:utf-8 -*- # ----------------------------------------------------- ...
- PAT_A1079#Total Sales of Supply Chain
Source: PAT A1079 Total Sales of Supply Chain (25 分) Description: A supply chain is a network of ret ...
- 24-Ubuntu-文件和目录命令-查找文件内容-grep
grep Linux系统中grep命令是一种强大的文本搜索工具. grep允许文本文件进行模式查找,所谓模式查找,又被称为正则表达式. 选项 含义 -n 显示匹配行及行号 -v 显示不包括匹配文本的所 ...
- (一)hello word
1.在如图demo文件夹下可以编写自己的后端代码. 我们编写hello的接口代码如下: @RestController @RequestMapping("/hello") @Slf ...
- websokect的原理
WebSocket 机制 以下简要介绍一下WebSocket的原理及运行机制. WebSocket是HTML5下一种新的协议.它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通 ...
- Django ORM 之基于对象、双下划线查询
返回ORM目录 Django ORM 内容目录: 一. 基于对象的表查询 二. 基于双下划线的查询 三. 聚合查询 aggregate 四. 分组查询 annotate 一. 基于对象的表查询 1.正 ...
- 5、Docker数据管理
为了能够存储持久化数据以及共享容器间的数据,Docker提出了Volume的概念.让我们通过类似mount的方式将宿主机的文件或者目录挂载到容器中. 在容器中管理数据主要有两种方式: 数据卷(Data ...
- exe4j 打包(多个jar打包)
一,自行下载exe4j 注册码: 用户名和公司名可随便填A-XVK258563F-1p4lv7mg7savA-XVK209982F-1y0i3h4ywx2h1A-XVK267351F-dpurrhny ...