2021.08.10 Euler函数总结

知识:

记 φ(n) 表示在 [1,n] 中与 n互质的数的个数。

1.p为质数,则

\[φ(p^l)=p^l-p=p^{l-1}(p-1)
\]

注:每p个数中就有一个数整除p^l

延伸1:若

\[n=p_1^{a_1}*p_2^{a_2}*P_3^{a_3}\cdots p_k^{a_k}
\]

\[φ(n)=p_1^{a_1-1}*(p_1-1)*p_2^{a_2-1}*(p_2-1)*p_3^{a_3-1}*(p_3-1)\cdots p_k^{a_k-1}*(p_k-1)
\]

延伸2:(m,n)=1,则

\[φ(mn)=φ(m)*φ(n)
\]

延伸3:若m|n,则

\[φ(mn)=m*φ(n)
\]

延伸4:令

\[f(n)=\sum_{d|n}φ(d)
\]

则f(n)=n

注:f(n)为积性函数。令

\[n=p_1^{a_1}*p_2^{a_2}*P_3^{a_3}\cdots p_k^{a_k}
\]

\[\begin{aligned}
f(p_i^{a_i})
& =φ(1)+φ(p_i)+φ(p_i^2)+\cdots +φ(p_i^{a_i})\\
& =1+(p_i-1)+p_i(p_i-1)+p_i^2(p_i-1)+\cdots +p_i^{a_i-1}(p_i-1)\\
& =p_i^{a_i}
\end{aligned}
\]

2.若p为质数,则

\[φ(p)=p-1
\]

延伸1:若p为质数,且p是n的最小质因子,p|n,即n=pt,则

\[φ(n)=\left\{
\begin{array}{lr}
φ(p)*φ(t)=(p-1)*φ(t) & (p,t)=1\\
p*φ(t) & (p,t)>1
\end{array}
\right.
\]

3.2|φ(n)(n>2)

注:若(x,n)=1,则(n-x,n)=1,所以当除了n=2*x时,所有x可以两两凑对。

练习题:

UVA11327 Enumerating Rational Numbers - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

重点:

1.线性筛欧拉函数

//euler函数+前缀和+暴力二分~
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std; const int N=2e5+10;
typedef long long ll;
ll top,k,vis[N],prime[N],oula[N],sum[N]; inline ll read(){
int s=0,w=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')w=-1;
ch=getchar();
}
while(ch<='9'&&ch>='0'){
s=s*10+ch-'0';
ch=getchar();
}
return s*w;
}
int gcd(int x,int y){
return y==0?x:gcd(y,x%y);
} int main(){
//线性筛欧拉函数
memset(vis,1,sizeof(vis));
oula[1]=1;vis[1]=0;
for(int i=2;i<=2e5;i++){
if(vis[i])oula[i]=i-1,prime[++top]=i;
for(int j=1;j<=top;j++){
if(i*prime[j]>2e5)break;
vis[i*prime[j]]=0;
if(i%prime[j])oula[i*prime[j]]=(prime[j]-1)*oula[i];
else{
oula[i*prime[j]]=prime[j]*oula[i];
break;
}
}
} for(int i=1;i<=2e5;i++)sum[i]=sum[i-1]+oula[i]; while(~scanf("%lld",&k)){
if(!k)return 0;
else if(k==1)cout<<"0/1"<<endl;
else if(k==2)cout<<"1/1"<<endl;
else{
--k;
int x=lower_bound(sum+1,sum+200000+1,k)-sum;
if(sum[x]==k){
cout<<x-1<<"/"<<x<<endl;
continue;
}
--x;
k-=sum[x];
++x;
if(k==1){
cout<<"1/"<<x<<endl;
continue;
}else{
--k;
for(int j=2;j<x;j++){
if(gcd(j,x)==1)--k;
if(!k){
cout<<j<<"/"<<x<<endl;
break;
}
}
}
}
}
return 0;
}

UVA10299 Relatives - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

重点:

1.性质1延伸1

//euler函数模板!!!刚打过UVA11327,本座记得很清楚~
//1e9的数据有点大,需要单点求euler函数——分解质因数
//详情请查看《初等数论2》第一章欧拉函数部分
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
using namespace std; const int N=1e9+10;
int k; inline int read(){
int s=0,w=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')w=-1;
ch=getchar();
}
while(ch<='9'&&ch>='0'){
s=s*10+ch-'0';
ch=getchar();
}
return s*w;
}
void euler(int x){
int ans=x,n=x;
for(int i=2;i*i<=n;i++){
if(n%i==0){
ans=ans/i*(i-1);
while(n%i==0)n/=i;
}
}
if(n>1)ans=ans/n*(n-1);
cout<<ans<<endl;
} int main(){
while(~scanf("%d",&k)){
if(!k)return 0;
if(k==1)cout<<"0"<<endl;
else euler(k);
}
return 0;
}

UVA10179 Irreducable Basic Fractions - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

//euler函数模板!!!刚打过UVA11327,本座记得很清楚~
//1e9的数据有点大,需要单点求euler函数——分解质因数
//详情请查看《初等数论2》第一章欧拉函数部分
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
using namespace std; const int N=1e9+10;
int k; inline int read(){
int s=0,w=1;
char ch=getchar();
while(ch<'0'||ch>'9'){
if(ch=='-')w=-1;
ch=getchar();
}
while(ch<='9'&&ch>='0'){
s=s*10+ch-'0';
ch=getchar();
}
return s*w;
}
void euler(int x){
int ans=x,n=x;
for(int i=2;i*i<=n;i++){
if(n%i==0){
ans=ans/i*(i-1);
while(n%i==0)n/=i;
}
}
if(n>1)ans=ans/n*(n-1);
cout<<ans<<endl;
} int main(){
while(~scanf("%d",&k)){
if(!k)return 0;
euler(k);
}
return 0;
}

2021.08.10 Euler函数总结的更多相关文章

  1. 2021.08.30 前缀函数和KMP

    2021.08.30 前缀函数和KMP KMP算法详解-彻底清楚了(转载+部分原创) - sofu6 - 博客园 (cnblogs.com) KMP算法next数组的一种理解思路 - 挠到头秃 - 博 ...

  2. 新手C#SQL Server使用记录2018.08.10

    主键(PrimaryKey):主键就是每个数据行(记录)的唯一标识,不会有重复值的列(字段)才能当做主键.一个表可以没有主键,但是这样会很难处理表,因此一般情况表都要设置主键. 主键有两张选用策略,分 ...

  3. 2021.08.16 P1260 工程规划(差分约束)

    2021.08.16 P1260 工程规划(差分约束) 重点: 1.跑最短路是为了满足更多约束条件. P1260 工程规划 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 造 ...

  4. 2021.08.16 P1078 文化之旅(最短路)

    2021.08.16 P1078 文化之旅(最短路) 题意: n个地,k个信仰,每个地都有自己的信仰,信仰之间会相互排斥,同信仰之间也会相互排斥,有m条路,问从s到t的最短距离是多少? 有一位使者要游 ...

  5. 2021.08.16 P1300 城市街道交通费系统(dfs)

    2021.08.16 P1300 城市街道交通费系统(dfs) P1300 城市街道交通费系统 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 城市街道交费系统最近创立了.一 ...

  6. 2021.08.16 P1363 幻象迷宫(dfs,我感受到了出题人浓浓的恶意)

    2021.08.16 P1363 幻象迷宫(dfs,我感受到了出题人浓浓的恶意) P1363 幻象迷宫 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 幻象迷宫可以认为是无限 ...

  7. 2021.08.09 P5658 括号树(树形结构)

    2021.08.09 P5658 括号树(树形结构) [P5658 CSP-S2019] 括号树 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 太长,在链接中. 分析及代码 ...

  8. 2021.08.09 P4868 Preprefix sum(树状数组)

    2021.08.09 P4868 Preprefix sum(树状数组) P4868 Preprefix sum - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 前缀和(pr ...

  9. 2021.08.09 P6037 Ryoku的探索(基环树)

    2021.08.09 P6037 Ryoku的探索(基环树) P6037 Ryoku 的探索 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 重点: 1.树的性质 2.基环树的性质 ...

随机推荐

  1. logging 日志配用

    第一步,创建一个logger: 第二步,创建一个handler,用于写入日志文件: 第三步,再创建一个handler,用于输出到控制台: 第四步,定义handler的输出格式: 第五步,将logger ...

  2. Skye无人机刷Betaflight详细图文教程

    ​前言 首先十分感谢B站TASKBL up主的视频教程以及他的耐心指导,视频链接Skye 原机主板刷BetaFlight 参考教程_哔哩哔哩_bilibili.整个改造过程耗时三天,现把改造过程以及遇 ...

  3. 变频器通讯参数PKW和PZD的含义

    SINAMICS S120 S150 参数手册 章节3.9 PROFIdrive 图3-41 功能图2422制造商专用报文和过程数据 参考:https://www.diangon.com/wenku/ ...

  4. Azure DevOps (七) 通过SSH部署上传到服务器的应用

    上一篇中,我们实现了通过FTP把流水线编译出来的制品上传到我们的公网服务器上,这一篇我们来研究一下通过azure的ssh连接到服务器 把应用在服务器上运行起来. 首先,我们书接上文,在release流 ...

  5. CentOS7防火墙开启与关闭以及开放6379,3306,80等端口

    CentOS7用firewall防火墙替代了原来的iptables,所以我们应该使用firewall的一些命令.如下:1.关闭防火墙 systemctl stop firewalld.service ...

  6. 说说 RPC 的实现原理?

    首先需要有处理网络连接通讯的模块,负责连接建立.管理和消息的传输.其次需要有编解码的模块,因为网络通讯都是传输的字节码,需要将我们使用的对象序列化和反序列化.剩下的就是客户端和服务器端的部分,服务器端 ...

  7. 面试问题之C++语言:说一说C++中四种cast转换

    C++中四种类型转换是:static_cast.dynamic_cast.const_cast.reinterpret_cast 1.const_cast 常量转换,用于将const变量转为非cons ...

  8. 表单属性method的值get和post的区别?什么时候用get?什么时候用post?

    get和post的区别 一.安全性 因为get会将用户名和密码放在URL中,进而出现在浏览器的历史记录中,显然这种情况应该用post. 二.编码 get只能向服务器发送ASCII字符,而post则可以 ...

  9. JDBC和桥接模式

    本文参考 网上对于JDBC与桥接模式的理解各有不同,在这片文章里提出的是我个人对于二者的理解,本文参考的其它博文如下: https://blog.csdn.net/paincupid/article/ ...

  10. servlet中的HttpServletRequest对象

    HttpServletRequest对象表示客户端浏览器发起的请求,当客户端浏览器通过HTTP协议访问服务器时,Tomcat会将HTTP请求中的所有信息解析并封装在HttpServletRequest ...