看破欧拉函数的奥秘

 

 

摘自百度百科

注意以下三个特殊性质

这里写图片描述

编程实现
  利用欧拉函数和它本身不同质因数的关系,用筛法计算出某个范围内所有数的欧拉函数值。

复制代码
 1 //直接求解欧拉函数  
 2 #include<cstdio>
 3 int euler(int n){ //返回euler(n)   
 4     int res=n,a=n;  
 5     for(int i=2;i*i<=a;i++){//从小到大尝试n的质因数 
 6         if(a%i==0){//如果i是n的质因数 
 7             res=res/i*(i-1);//提了一个1/i出来,先进行除法是为了防止中间数据的溢出   
 8             while(a%i==0) a/=i;//欧拉函数只记算一种质因数 
 9         }  
10     }  
11     if(a>1) res=res/a*(a-1);//如果最后还剩因子 
12     return res;  
13 }
14 int main(){
15     int x;
16     scanf("%d",&x);
17     printf("%d",euler(x));
18     return 0;
19 }
复制代码
复制代码
 1 //筛选法打欧拉函数表   
 2 #include<cstdio>
 3 #define Max 1000001  
 4 int euler[Max];  
 5 void Init(){
 6     euler[1]=1;
 7     for(int i=2;i<Max;i++)
 8         euler[i]=i;
 9     for(int i=2;i<Max;i++)
10         if(euler[i]==i)//如果i是质数 
11             for(int j=i;j<Max;j+=i) 
12                 euler[j]=euler[j]/i*(i-1);//提一个1/i,先进行除法是为了防止中间数据的溢出
13     return ;
14 }
15 int main()
16 {
17     Init();
18     for(int i=1;i<=100;i++)
19         printf("%d\n",euler[i]);
20     return 0;
21 }
复制代码

 

posted @   Angel_Kitty  阅读(410)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示
剑桥
14:14发布
剑桥
14:14发布
6°
南风
3级
空气质量
相对湿度
87%
今天
多云
4°/16°
周日
9°/18°
周一
大雨
8°/15°