BZOJ 2818: Gcd [欧拉函数 质数 线性筛]【学习笔记】
2818: Gcd
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 4436 Solved: 1957
[Submit][Status][Discuss]
Description
给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的
数对(x,y)有多少对.
1<=N<=10^7
uva上做过gcd(x,y)=1的题
gcd(x,y)=p ---> gcd(x/p,y/p)=1
每个质数做一遍行了
答案是欧拉函数的前缀和*2-质数的个数,因为(p,p)算一组
朴素的两个筛法写下来要5000ms
然后就学了一个新技能:欧拉筛法同时求欧拉函数
我们要证明:
若p是x的约数,则Φ(x*p)=Φ(x)*p.
若p不是x的约数,则Φ(x*p)=Φ(x)*(p-1).
欧拉函数是一个积性函数,且phi(p)=p-1 p is prime
若f(n)为数论函数,且f(1)=1,对于互质的正整数p,q有f(p⋅q)=f(p)⋅f(q),则称其为积性函数。
那么Φ(x*p)=Φ(x)*(p-1)
Φ(p^k)=p^k-p^(k-1)=(p-1)*p^(k-1)
证明:
令n=p^k,小于n的正整数数共有n-1即(p^k-1)个,其中不与p互质的数共[p^(k-1)-1]个(除以p然后下取整.....)
所以Φ(p^k)=(p^k-1)-(p^(k-1)-1)=p^k-p^(k-1) 得证。//定义
Φ(p^k)=(p-1)*p^(k-1)=(p-1)*p^(k-2)*p
Φ(p^(k-1))=(p-1)*p^(k-2)
所以当k>1时,Φ(p^k)=Φ(p^(k-1))*p
得证
复习欧拉筛法:对于任意一个合数,拆成最小质数*某个数字的形式,每个数字只会被筛选一次
2016的国家队论文里有一个语言描述比较好,复制不下来....
那么我们遇到一个数i,如果是素数phi[i]=i-1
然后在枚举i*p[j]时,phi[i]已经知道了,由以上两个式子就可以算出phi[i*p[j]]的值了
更一般的来说,就是因为线性筛的过程中得到了每个数的最小质因子,利用了积性函数的性质
【2016-12-22】上述直接观察也可以
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long ll;
const int N=1e7+;
int n;
bool vis[N];
int p[N],m=;
ll s[N],ans,phi[N];
void sieveprime(){
for(int i=;i<=n;i++){
if(!vis[i]) p[++m]=i;
for(int j=;j<=m&&i*p[j]<=n;j++){
vis[i*p[j]]=;
if(i%p[j]==) break;
}
}
}
void sievephi(){
phi[]=;
for(int i=;i<=n;i++)if(!phi[i]){
for(int j=i;j<=n;j+=i){
if(!phi[j]) phi[j]=j;
phi[j]=phi[j]/i*(i-);
}
}
for(int i=;i<=n;i++) s[i]=s[i-]+phi[i];
}
int main(){
scanf("%d",&n);
sieveprime();
sievephi();
for(int i=;i<=m;i++) ans+=s[n/p[i]];
printf("%lld",ans*-m);
}
朴素
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long ll;
const int N=1e7+;
int n;
bool vis[N];
int p[N],m=;
ll s[N],ans,phi[N];
void sieve(){
phi[]=;
for(int i=;i<=n;i++){
if(!vis[i]){
p[++m]=i;
phi[i]=i-;
}
for(int j=;j<=m&&i*p[j]<=n;j++){
vis[i*p[j]]=;
if(i%p[j]==){
phi[i*p[j]]=phi[i]*p[j];
break;
}
phi[i*p[j]]=phi[i]*(p[j]-);
}
}
for(int i=;i<=n;i++) s[i]=s[i-]+phi[i];
}
int main(){
scanf("%d",&n);
sieve();
for(int i=;i<=m;i++) ans+=s[n/p[i]];
printf("%lld",ans*-m);
}
BZOJ 2818: Gcd [欧拉函数 质数 线性筛]【学习笔记】的更多相关文章
- BZOJ 2818 Gcd(欧拉函数+质数筛选)
2818: Gcd Time Limit: 10 Sec Memory Limit: 256 MB Submit: 9108 Solved: 4066 [Submit][Status][Discu ...
- ACM学习历程—HYSBZ 2818 Gcd(欧拉函数 || 莫比乌斯反演)
Description 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. Input 一个整数N Output 如题 Sample Input 4 Sam ...
- BZOJ-2190 仪仗队 数论+欧拉函数(线性筛)
今天zky学长讲数论,上午水,舒爽的不行..后来下午直接while(true){懵逼:}死循全程懵逼....(可怕)Thinking Bear. 2190: [SDOI2008]仪仗队 Time Li ...
- Poj 2478-Farey Sequence 欧拉函数,素数,线性筛
Farey Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14291 Accepted: 5647 D ...
- 洛谷UVA12995 Farey Sequence(欧拉函数,线性筛)
洛谷题目传送门 分数其实就是一个幌子,实际上就是求互质数对的个数(除开一个特例\((1,1)\)).因为保证了\(a<b\),所以我们把要求的东西拆开看,不就是\(\sum_{i=2}^n\ph ...
- 欧拉函数(线性筛)(超好Dong)
欧拉函数:对于一个正整数n,小于n且和n互质的正整数(包括1)的个数,记作φ(n) . #include <bits/stdc++.h> using namespace std; cons ...
- BZOJ2186 [Sdoi2008]沙拉公主的困惑 【数论,欧拉函数,线性筛,乘法逆元】
2186: [Sdoi2008]沙拉公主的困惑 Time Limit: 10 Sec Memory Limit: 259 MB Submit: 5003 Solved: 1725 [Submit] ...
- Bzoj 2749: [HAOI2012]外星人 欧拉函数,数论,线性筛
2749: [HAOI2012]外星人 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 568 Solved: 302[Submit][Status][ ...
- [bzoj2226][Spoj5971]LCMSum_欧拉函数_线性筛
LCMSum bzoj-2226 Spoj-5971 题目大意:求$\sum\limits_{i=1}^nlcm(i,n)$ 注释:$1\le n\le 10^6$,$1\le cases \le 3 ...
随机推荐
- ASP.NET Web API与Owin OAuth:调用与用户相关的Web API
在前一篇博文中,我们通过以 OAuth 的 Client Credential Grant 授权方式(只验证调用客户端,不验证登录用户)拿到的 Access Token ,成功调用了与用户无关的 We ...
- 配置 LBaaS - 每天5分钟玩转 OpenStack(121)
上一节学习了 Neutron LBaaS 的原理,今天开始实践.首先在配置中启用 LBaaS 服务. Neutron 通过 lbaas plugin 和 lbaas agent 提供 LBaaS 服务 ...
- ionic之$ionicGesture手势(大坑)
鄙人来本公司前未用过ionic框架,但由于ionic是基于angularjs封装的,正好我用过angularjs,很荣幸的面试就过了,然后通过该网站http://www.ionic.wang(后面简称 ...
- javascript编程杂记
1.数组深复制 var obj =[1,2,4]: var obj2 = obj.slice(0);
- Apache Hadoop2.x 边安装边入门
完整PDF版本:<Apache Hadoop2.x边安装边入门> 目录 第一部分:Linux环境安装 第一步.配置Vmware NAT网络 一. Vmware网络模式介绍 二. NAT模式 ...
- 查看Sql Server被锁的表以及解锁
查看被锁表: select spId from master..SysProcesses where db_Name(dbID) = '数据库名称' and spId <> @@SpId ...
- struts2类型转换
1. Struts2中的类型转换 我们知道通过HTTP提交到后台的数据,都是字符串的形式,而我们需要的数据类型当然不只字符串类型一种.所以,我们需要类型转换! 在Struts2中,类型转换的概念除了用 ...
- GJM: 设计模式 - 模板方法模式(Template Method)
生活中的模板 一.在银行办理业务 Step1:进门取号 Step2:填写单据 Step3:等待叫号 Step4:窗口办理 二.奥运会开幕式 第一步:升国旗奏国歌 第二步:领导人致辞讲话 第三部: 文艺 ...
- Egret Wiing3快捷键
删除当前行 ( Ctrl+Shift+k ),EgretWing2.5下为 Ctrl+D 折叠 ( Ctrl+Shift+[ ) 展开 ( Ctrl+Shift+] ) Ctrl+Shift+P呼出面 ...
- 图片的赖加载(lazyLoad)
懒加载的意义(在线demo预览) 尽管很多公司的网页都有一些限制,比如页面的最大的图片大小不得大于50k,也有很多图片优化工具fis3.gulp等等,但是如果图片太多还是会影响页面的加载速度,快则几十 ...