UVA11426 GCD - Extreme (II)

题目描述

PDF

输入输出格式

输入格式:

输出格式:

输入输出样例

输入样例#1:

10

100

200000

0

输出样例#1:

67

13015

143295493160

Solution

这道题我用莫比乌斯反演和欧拉函数都写了一遍,发现欧拉函数比莫比乌斯反演优秀?

求所有\(gcd=k\)的数对的个数,记作\(f[k],ans=\sum_{i=1}^{n}(f[i]-1)\),为什么还要-1,我们注意到\(j=i+1\),自己与自己是不算的,再乘上这个数的大小\(k\)就可以了

我们发现要求\(\sum_{i=1}^{n-1}\sum_{j=i+1}^{n}{gcd(i,j)}\),我们令\(gcd(i,j)=k\),则必有\(gcd(a\times k,b\times k)=k\to gcd(a,b)=1\),我们枚举这两个数中大的那个,另一个数就有\(phi[i](1<=i <=n/k)\)个,所以\(f[n]=\sum_{i=1}^{n/k}\phi(i)\)

筛一下欧拉函数求前缀和就可以了

那么?莫比乌斯反演怎么写呢?

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

\(ans=\sum_{i=1}^{n}\sum_{j=1}^{n}gcd(i,j)\)

我么观察这两个式子的区别,一个是从j从1开始,另一个是从i+1开始,这两个式子是具有几何意义的,上面的式子求得是一个三角形的答案(且不包括对角线),下面的是矩形.那么我们用下面的式子-对角线上的答案再除以2就是上面的答案了

(对角线上的答案就是\(gcd(i,i)=i\),所以一个等比数列求和就好了)

下面的式子很好反演,套路套路....

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

\[\sum_{d=1}^{n}d\sum_{p=1,p|i,p|j}^{\lfloor\frac{n}{d}\rfloor}\mu(p) \lfloor\frac{n}{d\times p}\rfloor\lfloor\frac{n}{d\times p}\rfloor
\]

线性筛莫比乌斯函数,然后套个整除分块就好了(还是没有第一种方法快,如果莫比乌斯反演有比博主还快的方法,请告知我)

Code1

#include<bits/stdc++.h>
#define lol long long
#define il inline
#define rg register
#define Min(a,b) (a)<(b)?(a):(b)
#define Max(a,b) (a)>(b)?(a):(b)
#define NN 4000000 using namespace std; const int N=4e6+10;
int n,tot;
lol phi[N],prime[N];
bool vis[N]; il void init() {
phi[1]=1;
for(rg int i=2;i<=NN;i++) {
if(!vis[i]) prime[++tot]=i,phi[i]=i-1;
for(rg int j=1;j<=tot && i*prime[j]<=NN;j++) {
vis[i*prime[j]]=1;
if(i%prime[j]==0) {
phi[i*prime[j]]=phi[i]*prime[j];
}
else phi[i*prime[j]]=phi[i]*(prime[j]-1);
}
}
for(rg int i=1;i<=NN;i++) phi[i]+=phi[i-1];
}
int main()
{
ios::sync_with_stdio(0);
init();
while(cin>>n) {
lol ans=0;
if(n==0) break;
for(rg int i=1;i<=n;i++) ans+=1ll*(phi[n/i]-1)*i;
cout<<ans<<endl;
}
}

Code2

#include<bits/stdc++.h>
#define in(i) (i=read())
#define il extern inline
#define rg register
#define mid ((l+r)>>1)
#define ll(x) (x<<1)
#define rr(x) (x<<1|1)
#define Min(a,b) ((a)<(b)?(a):(b))
#define Max(a,b) ((a)>(b)?(a):(b))
#define lol __int128
using namespace std; const lol N=4e6+10; lol read() {
lol ans=0, f=1; char i=getchar();
while (i<'0' || i>'9') {if(i=='-') f=-1; i=getchar();}
while (i>='0' && i<='9') ans=(ans<<1)+(ans<<3)+(i^48), i=getchar();
return ans*f;
} lol cnt;
lol vis[N]={0,1},prime[N],mu[N]={0,1}; void init() {
for (lol i=2;i<=N-10;i++) {
if(!vis[i]) prime[++cnt]=i,mu[i]=-1;
for (lol j=1;j<=cnt && prime[j]*i<=N-10;j++) {
vis[i*prime[j]]=1;
if(i%prime[j]==0) break;
mu[i*prime[j]]=-mu[i];
}
}for (lol i=1;i<=N-10;i++) mu[i]+=mu[i-1];
} lol work(lol d,lol n,lol ans=0) {
n/=d;
for (lol l=1,r;l<=n;l=r+1) {
r=n/(n/l);
ans+=(mu[r]-mu[l-1])*(n/l)*(n/l);
}return ans;
} int main()
{
long long ans,n; init();
while(scanf("%lld",&n)==1 && n) {
ans=0;
for (lol i=1;i<=n;i++) ans+=i*work(i,n);
printf("%lld\n",(ans-(n+1)*n/2)/2);
}
return 0;
}

UVA11426 GCD - Extreme (II) (欧拉函数/莫比乌斯反演)的更多相关文章

  1. UVA11426 GCD - Extreme (II) —— 欧拉函数

    题目链接:https://vjudge.net/problem/UVA-11426 题意: 求 ∑ gcd(i,j),其中 1<=i<j<=n . 题解:1. 欧拉函数的定义:满足 ...

  2. UVA11426 GCD - Extreme (II)---欧拉函数的运用

    题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  3. UVA 11426 GCD - Extreme (II) (欧拉函数+筛法)

    题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=70017#problem/O 题意是给你n,求所有gcd(i , j)的和,其中 ...

  4. UVA 11426 GCD - Extreme (II)(欧拉函数打表 + 规律)

    Given the value of N, you will have to find the value of G. The definition of G is given below:Here ...

  5. uva 11426 GCD - Extreme (II) (欧拉函数打表)

    题意:给一个N,和公式 求G(N). 分析:设F(N)= gcd(1,N)+gcd(2,N)+...gcd(N-1,N).则 G(N ) = G(N-1) + F(N). 设满足gcd(x,N) 值为 ...

  6. UVA 11426 - GCD - Extreme (II) 欧拉函数-数学

    Given the value of N, you will have to find the value of G. The definition of G is given below:G =i< ...

  7. UVA 11426 GCD - Extreme (II) 欧拉函数

    分析:枚举每个数的贡献,欧拉函数筛法 #include <cstdio> #include <iostream> #include <ctime> #include ...

  8. UVA 11424 GCD - Extreme (I) (欧拉函数+筛法)

    题目:给出n,求gcd(1,2)+gcd(1,3)+gcd(2,3)+gcd(1,4)+gcd(2,4)+gcd(3,4)+...+gcd(1,n)+gcd(2,n)+...+gcd(n-1,n) 此 ...

  9. GCD - Extreme(欧拉函数变形)

    题目链接:https://vjudge.net/problem/UVA-11426 题目大意: 给出整数n∈[2,4000000],求解∑gcd(i,j),其中(i,j)满足1≤i<j≤n. 的 ...

随机推荐

  1. leetcode-下一个排列

    下一个排列 实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列. 如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列). 必须原地修改,只允许使用额外 ...

  2. MySQL双主复制

    原文发表于cu:2017-06-12 本文简单介绍MySQL双主复制原理及1个简单是双主复制验证. 一.MySQL双主复制原理 1. 双主复制原理 master-master复制的两台服务器,既是ma ...

  3. html页面中完成查找功能

    最近在搞一个被很多人改了的框架,天天看代码看的头的晕了,不过感觉进步还挺大的,自己做了一个后台可配置前台查看两个库不同数据范围的东西,还挺满意,那天拿出来分享一下,今天先说一个这几天做的功能,就是ht ...

  4. HPUX修改disk实例号--11.31only

    有时由于一些原因或者用户的要求,需要修改Disk的实例号,这里简单介绍如何手工进行修改. 在修改之前需要做一些准备工作,即先将stale状态的设备文件清理掉,具体步骤如下: 使用ioscan命令列出s ...

  5. Method 'ExecuteAsync' in type 'System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy' does not have an implementation

    一.错误信息 Entity Framework 6.0数据迁移:Add-Migration XXXX 命令发生错误 System.Reflection.TargetInvocationExceptio ...

  6. 第九次ScrumMeeting博客

    第九次ScrumMeeting博客 本次会议于11月4日(六)22时整在3公寓725房间召开,持续20分钟. 与会人员:刘畅.辛德泰.窦鑫泽.张安澜.赵奕.方科栋. 1. 每个人的工作(有Issue的 ...

  7. USACO 1.4.2 Mother's Mil 母亲的牛奶(DFS)

    Description 农民约翰有三个容量分别是A,B,C升的桶,A,B,C分别是三个从1到20的整数,最初,A和B桶都是空的,而C桶是装满牛奶的.有时,约翰把牛奶从一个桶倒到另一个桶中,直到被灌桶装 ...

  8. Scrum立会报告+燃尽图(十一月二十六日总第三十四次):上传β阶段展示视频

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2413 项目地址:https://git.coding.net/zhang ...

  9. 软工第十二周个人PSP

    11.30--12.6本周例行报告 1.PSP(personal software process )个人软件过程. C(类别) C(内容) ST(开始时间) ET(结束时间) INT(间隔时间) Δ ...

  10. c# 读取blob数据

    Stream stream = new MemoryStream(data); BinaryReader r = new BinaryReader(stream); int iRawImageWidt ...