【HUSTOJ】1036: 欧拉函数
来源:互联网 发布:数据融合是数据预处理 编辑:程序博客网 时间:2024/05/22 00:25
1036: 欧拉函数
Time Limit: 1 Sec Memory Limit: 128 MBDescription
欧拉函数 表示小于n且与n互素的正整数的个数。例如, (小于12且与12互素的正整数共有4个:1、5、7和11)。
现给出整数n(2<=n<2^31),要求计算 的值。
现给出整数n(2<=n<2^31),要求计算 的值。
Input
一个整数n。
Output
仅一行,一个整数 。
Sample Input
12
Sample Output
4
HINT
关于本题有数学公式,可自行查找。
Source
#include<iostream>#include<cmath>using namespace std; //计算欧拉数 int ol(int n){ int s=n,i,m; m=sqrt(n); for(i=2;i<=m;i++){ if(n%i==0) s=s/i*(i-1); //φ(n)=p^k-p^(k-1)=(p-1)p^(k-1) while(n%i==0) n/=i; //去掉剩下的p因子 } if(n>1) s=s/n*(n-1); return s;}main(){int n;cin>>n;cout<<ol(n)<<endl;}
/*(1)若n是素数p的k次幂,φ(n)=p^k-p^(k-1)=(p-1)p^(k-1),因为除了p的倍数外,其他数都跟n互质
(2)欧拉函数是积性函数——若m,n互质,φ(mn)=φ(m)φ(n)
特殊性质:
1)当n为奇数时,φ(2n)=φ(n)
2)p是素数,φ(p) = p - 1,φ(p)称为p的欧拉值
*/
(2)欧拉函数是积性函数——若m,n互质,φ(mn)=φ(m)φ(n)
特殊性质:
1)当n为奇数时,φ(2n)=φ(n)
2)p是素数,φ(p) = p - 1,φ(p)称为p的欧拉值
*/
0 0
- 【HUSTOJ】1036: 欧拉函数
- 【HUSTOJ】1012: 分段函数
- 欧拉函数
- 欧拉函数
- Relatives 【欧拉函数】
- 欧拉函数
- POJ_2407_欧拉函数
- 欧拉函数
- hdu_3501_欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数应用
- 欧拉函数
- 欧拉函数
- vi/vim使用入门: vimrc在哪儿?
- C - Tanya and Toys
- C++10进制字符串与十六进制字符串相互转化
- 【SignalR-支持平台】
- 《java入门第一季》之面向对象面试题(继承中构造方法的关系)
- 【HUSTOJ】1036: 欧拉函数
- unity中使用protobuf(兼容ios平台)
- 【西西学FPGA】Lesson1
- 绝对定位
- CentOS6.4升级python2.6.6到3.3.0
- 【西西学FPGA】Lesson2
- Swift笔记-让你2小时学会Swift
- Jmeter结果各参数含义
- 【USACO题库】1.3.3 Calf Flac(manacher马拉车算法)