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 ...
随机推荐
- hdu多校第五场1007 (hdu6630) permutation 2 dp
题意: 给你n个数,求如下限制条件下的排列数:1,第一位必须是x,2,最后一位必须是y,3,相邻两位之差小于等于2 题解: 如果x<y,那么考虑把整个数列翻转过来,减少讨论分支. 设dp[n]为 ...
- jsp-request应用1
用jsp写表单提交数据时需要用到request去读取数据,表单代码如下: <form action="requestresult.jsp" method="post ...
- arr = map(float,arr)输出问题
代码: arr = ['22','44','66','88']arr = map(float,arr)print(arr) 输出: <map object at 0x000001B48C30EE ...
- ES6 学习 -- 箭头函数(=>)
(1).只有一个参数且只有一句表达式语句的,函数表达式的花括号可以不写let test = a => a; // 只有一个参数a,这里的表达式相当于 "return a" ( ...
- Tomcat Geoserver等服务器 端口号修改
端口号修改是我们经常会用到的,这里整理一下我们常见的服务器端口号修改位置,后面在用到的时候会持续更新 注意:端口号修改服务都需要重启才有效. 1.Tomcat 位置:..\tomcat路径\conf\ ...
- JAVA API about HTTP 2
import java.io.IOException; import java.nio.charset.Charset; import java.security.KeyManagementExcep ...
- RabbitMQ学习第一记:用java连接RabbitMQ
1.什么是RabbitMQ MQ(Message Queue):消息队列,是服务端设计的一个可以存储大量消息的队列,并提供客户端操作队列的方法:生产队列(向队列中添加数据).消费队列(从队列中取数据) ...
- The linux command 之存储媒介
一.常用的命令 mount:挂载文件系统 unmount:卸载文件系统 fdisk:硬盘分区命令 fdformat:格式化软盘 fsck:检查和修复文件系统 mkfs:创建文件系统 dd:转换和拷贝一 ...
- PHP算法之增减字符串匹配
给定只含 "I"(增大)或 "D"(减小)的字符串 S ,令 N = S.length. 返回 [0, 1, ..., N] 的任意排列 A 使得对于所有 i ...
- PHP算法之两数相加
给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和 ...