欧拉函数
来源:互联网 发布:Python 异常 编辑:程序博客网 时间:2024/06/15 01:41
新年快到了,“猪头帮协会”准备搞一个聚会,已经知道现有会员N人,把会员从1到N编号,其中会长的号码是N号,凡是和会长是老朋友的,那么该会员的号码肯定和N有大于1的公约数,否则都是新朋友,现在会长想知道究竟有几个新朋友?请你编程序帮会长计算出来。
22560824027
768016016
转:
定义:对于正整数n,φ(n)是小于或等于n的正整数中,与n互质的数的数目。
例如:φ(8)=4,因为1,3,5,7均和8互质。
性质:1.若p是质数,φ(p)= p-1.
2.若n是质数p的k次幂,φ(n)=(p-1)*p^(k-1)。因为除了p的倍数都与n互质
3.欧拉函数是积性函数,若m,n互质,φ(mn)= φ(m)φ(n).
根据这3条性质我们就可以推出一个整数的欧拉函数的公式。因为一个数总可以写成一些质数的乘积的形式。
E(k)=(p1-1)(p2-1)...(pi-1)*(p1^(a1-1))(p2^(a2-1))...(pi^(ai-1))
= k*(p1-1)(p2-1)...(pi-1)/(p1*p2*...*pi)
= k*(1-1/p1)*(1-1/p2)...(1-1/pk)
在程序中利用欧拉函数如下性质,可以快速求出欧拉函数的值(a为N的质因素)
若( N%a ==0&&(N/a)%a ==0)则有:E(N)= E(N/a)*a;
若( N%a ==0&&(N/a)%a !=0)则有:E(N)= E(N/a)*(a-1);
#include<stdio.h>int E(int n){int ans=n,i,c; c=n;for(i=2;i*i<=n;i++){if(n%i==0){ans-=ans/i;while(n%i==0)n/=i; }}if(n>1)ans-=ans/n;return ans;}int main(){int m,n,i,ans;scanf("%d",&m);while(m--){scanf("%d",&n);ans=E(n);printf("%d\n",ans);}return 0;}
阅读全文
1 0
- 欧拉函数
- 欧拉函数
- Relatives 【欧拉函数】
- 欧拉函数
- POJ_2407_欧拉函数
- 欧拉函数
- hdu_3501_欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数
- 欧拉函数应用
- 欧拉函数
- 欧拉函数
- 欧拉函数
- ACM-欧拉函数
- Is It A Tree? (并查集)
- Make defensive copies when needed
- 19、二叉树的镜像
- Android中ViewPager常用功能4补充----viewpager图片查看器
- JAVA实现较完善的布隆过滤器
- 欧拉函数
- Thread.join()的使用
- POJ 3167 Layout(差分约束)
- Red Gate系列之一 SQL Compare 10.4.8.87 Edition 数据库比较工具 完全破解+使用教程
- Mycat之——高可用负载均衡集群的实现(HAProxy + Keepalived + Mycat)
- 延迟消息队列实现分析与设计
- easyui-datagrid行内可编辑
- uva 836 Largest Submatrix
- Openlayers3中实现台风风圈绘制算法