博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ACdream 1114(莫比乌斯反演)
阅读量:6849 次
发布时间:2019-06-26

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

 

传送门:

题意:给n个数,n 和 每个数的范围都是 1---222222,求n个数中互质的对数。

分析:处理出每个数倍数的个数cnt[i],然后进行莫比乌斯反演,只不过这里的F(i)=cnt[i]*(cnt[i]-1)/2.

#pragma comment(linker,"/STACK:1024000000,1024000000")#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define LL long long#define mod 100000000#define inf 0x3f3f3f3f#define eps 1e-6#define N 222222#define lson l,m,rt<<1#define rson m+1,r,rt<<1|1#define PII pair
using namespace std;inline int read(){ char ch=getchar();int x=0,f=1; while(ch>'9'||ch<'0'){ if(ch=='-')f=-1;ch=getchar();} while(ch<='9'&&ch>='0'){x=x*10+ch-'0';ch=getchar();} return x*f;}bool vis[N+5];int mu[N+5],prime[N+5],sum[N+5];void Mobius(){ memset(vis,false,sizeof(vis)); mu[1]=1; int tot=0; for(int i=2;i<=N;i++) { if(!vis[i]) { prime[tot++]=i; mu[i]=-1; } for(int j=0;j
N)break; vis[i*prime[j]]=true; if(i%prime[j]==0) { mu[i*prime[j]]=0; break; } else { mu[i*prime[j]]=-mu[i]; } } } for(int i=1;i<=N;i++)sum[i]=sum[i-1]+mu[i];}int num[N+5],cnt[N+5];LL solve(int n){ LL res=0; for(int i=1;i<=n;i++) { if(!cnt[i])continue; res+=1LL*mu[i]*cnt[i]*(cnt[i]-1)/2; } return res;}int main(){ int n,x; Mobius(); while(scanf("%d",&n)>0) { memset(num,0,sizeof(num)); memset(cnt,0,sizeof(cnt)); int mx=0; for(int i=1;i<=n;i++) { x=read(); num[x]++; mx=max(x,mx); } for(int i=1;i<=mx;i++) for(int j=i;j<=mx;j+=i) cnt[i]+=num[j]; LL ans=solve(mx); printf("%lld\n",ans); }}
View Code

 

转载于:https://www.cnblogs.com/lienus/p/4296737.html

你可能感兴趣的文章
我的友情链接
查看>>
我的友情链接
查看>>
mybatis大数据提交和更新,数据SQL语句批量提交数据库
查看>>
每天一个小算法(Shell Sort2)
查看>>
Java数据结构与算法(7) - ch05双向链表(Double List)
查看>>
自适应布局
查看>>
L2-015. 互评成绩
查看>>
poj3186 poj3267
查看>>
L365
查看>>
js中with、this的用法
查看>>
子数组的和的最大值(包括升级版的首尾相连数组)
查看>>
LeetCode - Nth Highest Salary
查看>>
9.ORM数据访问
查看>>
一言不合就动手系列篇一-仿电商平台前端搜索插件(filterMore)
查看>>
Oracle Split 函数
查看>>
目标跟踪之卡尔曼滤波---理解Kalman滤波的使用预测
查看>>
Git安装和基本使用(1)
查看>>
Swoft 图片上传与处理
查看>>
BluetoothClass详解
查看>>
Centos 7安装Python3.6
查看>>