Phi的反函数
P4780 Phi的反函数
Phi(\(\varphi\) )定义
\(\varphi(n)\) 代表从1-n所有与n互质的数的个数
求\(\varphi(n)\)
普通求法:
首先将n唯一分解为
\(n=x_1^{p_1}*x_2^{p_2}……*x_n^{p_n}\)
\(\varphi(n)=n*(1-\frac1{x_1})*(1-\frac1{x_2})*……*(1-\frac1{x_n})\)
证明:
首先我们考虑在所有数中有\(\frac{1}{x}\)的概率会取到一个数是x的倍数,那么有\((1-\frac{1}{x})\)的概率会取到一个数不是x的倍数,1-n有n个数,我们要找到1-n所有与n互质的数,也就是去一个不是n的任意一个因数(x1,x2,x3……xn)的倍数,就得到以上式子
两个定理:
\varphi(nm)=\varphi(n)*\varphi(m)~~~~~gcd(n,m)=1\\
\varphi(nm)=\varphi(n)*m~~~~~~~~~~~gcd(n,m)=m
\end{cases}
\]
定理1证明:
1.在gcd(n,m)=1情况下
根据上述式子可以推导:
\(n=x_1^{p_1}*x_2^{p_2}……*x_n^{p_n}\)
\(m=y_1^{q_1}*y_2^{q_2}……*y_n^{q_n}\)
\(n*m=x_1^{p_1}*x_2^{p_2}……*x_n^{p_n}*y_1^{q_1}*y_2^{q_2}……*y_n^{q_n}\)
\(\varphi(nm)=n*m*(1-\frac1{x_1})……*(1-\frac1{x_n})*(1-\frac1{y_1})……*(1-\frac1{y_n})=\varphi(n)*\varphi(m)~~~~~~~~~~~~gcd(n,m)=m\)
2.在gcd(n,m)=m情况下
考虑感性理解,1-n里面有\(\varphi(n)\)个与n互质,那么扩大m倍,相当于有m个1-n就直接乘(因为我们保证了\(gcd(n,m)=m\)也就是n是m的倍数,所以不存在乘上m后多出了不属于n的因子)
定理2.\(\varphi(n)=n-1~~~~~~~~~~~~~n\in prim\)(这显而易见)
我们需要求Phi的反函数就要先深刻理解上述内容然后进行运用
可以根据上述定理1得到:
(在这里我们用到了定理一第一类和定理一第二类的一种特殊情况\(\varphi(n*n)=\varphi(n)*n\))
得出\(\varphi(x)=\varphi(a_1)*a_1^{p_1-1}*\varphi(a_2)*a_2^{p_2-1}*......\varphi(a_n)*a_n^{p_n-1}~~~~~~~~~~~~~~~~~~a_i\in prime\)
由定理二得:\(a_i\)都是质数,所以\(\varphi(a_i)=a_i-1\)
所有质数分解出来不超过10个,因为\(2*3*5*7*11*13*17*19*23*29=6469693230\)
\(~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~2^{31}=2147483648\)
所以可以直接暴力搜索
(关于判断是否为质数的函数)
因为数据范围在2^{31} ,如果我们求2^{31} 范围内的质数,直接爆炸,
其实我们只需要找出2^{16}的质数,每次判断一下当前这个数now+1(也就是\(revphi(now)\))是不是质数
例如\(\varphi(x)=n=\varphi(3)*varphi(1e9+7)\)
第一次找到\(\varphi(3)\)处理以后,由于我们只找了2^{16}的质数,我们找不到\(\varphi(1e9+7)\)在里面,我们需要每次判断当前这是数是不是质数。
具体的:
第一次判断\(\varphi(3)*varphi(1e9+7)\)显然不是质数
除以\(\varphi(3)\)后变成了\(\varphi(1e9+7)\) 也就是now=1e9+6
第二次判断\((now+1)\in prime\) 那么直接把质数给除了,直接结束了AWA
那么怎么得出答案呢
\varphi(nm)=\varphi(n)*\varphi(m)~~~~~gcd(n,m)=1\\
\varphi(nm)=\varphi(n)*m~~~~~~~~~~~gcd(n,m)=m
\end{cases}
\]
\(\varphi(x)=\varphi(a_1)*a_1^{p_1-1}*\varphi(a_2)*a_2^{p_2-1}*......\varphi(a_n)*a_n^{p_n-1}~~~~~~~~~~~~~~~~~~a_i\in prime\)
我们再来重新看看这些式子
可以看出最后的\(ans=a_1*a_1^{p_1-1}*a_2*a_2^{p_2-1}*......*a_n*a_n^{p_n-1}\)
代码:
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=1e7+10;
int vis[N],s[30],tot=0,n,cnt=0;
ll ans=1e17+10,prim[N];
void shai(int x){
for(int i=2;i<=x;i++){
if(!vis[i]){
prim[++tot]=i;
}
for(int j=1;j<=tot&&i*prim[j]<=x;j++){
vis[prim[j]*i]=1;
if(!i%prim[j]){
break;
}
}
}
}//质数筛
bool is_p(ll x){
for(int i=2;i*i<=x;i++){
if(x%i==0){
//cout<<x<<i<<endl;
return 0;
}
}
return 1;
}//判断是否为质数
void dfs(int now,int id,ll rev){//id代表当前干过的质数,是个优化
if(now>=ans) return ;//简单优化
if(now==1){
ans=min(rev,ans);
return ;
}
if(is_p(now+1)) dfs(1,id+1,rev*(now+1));
for(int i=id;i<=tot;i++){
if(now%(prim[i]-1)==0){
int a=now;
ll b=rev;
a/=(prim[i]-1);b*=prim[i]; //定理1的情况1
dfs(a,i+1,b);
while(a%prim[i]==0){//定理1的情况2
a/=prim[i];b*=prim[i];
dfs(a,i,b);
}
}
}
}
int main(){
scanf("%d",&n);
shai(sqrt(n)+1);
dfs(n,1,1);
if(ans==1e17+10){//无解或者太大了
printf("-1");
}else printf("%lld",ans);
return 0;
}
Phi的反函数的更多相关文章
- 【BZOJ-3643】Phi的反函数 数论 + 搜索
3643: Phi的反函数 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 141 Solved: 96[Submit][Status][Discuss ...
- bzoj3643 Phi的反函数
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3643 [题解] n = p1^a1*p2^a2*...*pm^am phi(n) = p1( ...
- 【BZOJ 3642】Phi的反函数
http://www.lydsy.com/JudgeOnline/problem.php?id=3643 因为\[\varphi(n)=\prod_i p_i^{k_i-1}(p_i-1),n=\pr ...
- [BZOJ]3643 Phi的反函数
我承认开这篇文章只是因为好笑…… 估计Zky神看见3737会很郁闷吧. http://www.lydsy.com/JudgeOnline/problem.php?id=3643 本来想直接交3737改 ...
- 【BZOJ 3643】Phi的反函数 数搜索
这道题是典型的数搜索,讲究把数一层一层化小,而且还有最重要的大质数剪枝. #include <cstdio> #include <cmath> typedef long lon ...
- bzoj 3643Phi的反函数
3643: Phi的反函数 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 298 Solved: 192[Submit][Status][Discus ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- bzoj题目分类
转载于http://blog.csdn.net/creationaugust/article/details/513876231000:A+B 1001:平面图最小割,转对偶图最短路 1002:矩阵树 ...
- LLVM 笔记(二)—— PHI node
ilocker:关注 Android 安全(新手) QQ: 2597294287 什么是 PHI node? 所有 LLVM 指令都使用 SSA (Static Single Assignment,静 ...
- LLVM 笔记(一)—— phi 指令
ilocker:关注 Android 安全(新手) QQ: 2597294287 语法: <result> = phi <ty> [ <val0>, <lab ...
随机推荐
- JavaScript之数组高阶API—reduce()
一文搞懂JavaScript数组中最难的数组API--reduce() 前面我们讲了数组的一些基本方法,今天给大家讲一下数组的reduce(),它是数组里面非常重要也是比较难的函数,那么这篇文章就好好 ...
- Java注解和反射笔记
Java注解和反射笔记 1 注解 1.1 定义 Annotation是从JDK1.5开始引入的技术 作用 不是程序本身,可以对程序作出解释 可以被其他程序(编译器等)读取 格式 @注释名,可以添加一些 ...
- 详解从浏览器地址栏输入URL到页面显示的步骤
版本1(基础版本) 步骤1:浏览器根据请求的 URL 交给 DNS 域名解析,找到真实 IP ,向服务器发起请求: 步骤2:服务器交给后台处理完成后返回数据,浏览器接收⽂件( HTML.JS.CSS ...
- Linux内核替换的一种简单方法
前言 使用现有centos的镜像,在海光机器上出现了无法运行的情况,grub引导后就只剩下光标一直在闪,无任何字符输出.这种情况大概率是因为Linux的内核无法运行在海光的CPU上所导致的. 已得知L ...
- 什么是 X.509 证书以及它是如何工作的?
X.509 证书是基于广泛接受的国际电信联盟 (ITU) X.509 标准的数字证书,该标准定义了公钥基础设施 (PKI) 证书的格式. 它们用于管理互联网通信和计算机网络中的身份和安全. 它们不显眼 ...
- Vue使用Element表单校验错误Cannot read property ‘validate’ of undefined
在做注册用户的页面使用表单校验一直提示Cannot read property 'validate' of undefined错误,其实这个错误的提示根据有多种情况,比较常见的就是 ref 的名字不一 ...
- linux系统移植
1 linux环境搭建 1.1 添加交叉开发工具链 新建如下工程目录: gcc-4.6.4.tar.xz #拷贝 tar -Jxvf gcc-4.6.4.tar.xz #解压 cd ./gcc-4.6 ...
- MyEclipse反编译插件安装于使用
在MyEclipse开发中,使用反编译插件可以对jar包的源码进行随机的查看,节约了使用jd-gui查看时间. 百度云分享地址:链接:https://pan.baidu.com/s/1efNR6A 密 ...
- Forest + IDEA = 双倍快乐!ForestX 隆重登场
Forest + IDEA = 双倍快乐!ForestX 隆重登场 Forest 是一款声明式的 Java 开源 HTTP 框架,相比它的前辈 Httpclient 和 OkHttp 更简明易懂.也更 ...
- 结合RocketMQ 源码,带你了解并发编程的三大神器
摘要:本文结合 RocketMQ 源码,分享并发编程三大神器的相关知识点. 本文分享自华为云社区<读 RocketMQ 源码,学习并发编程三大神器>,作者:勇哥java实战分享. 这篇文章 ...