zoukankan      html  css  js  c++  java
  • 欧拉函数

     欧拉函数

     
     
     

    给定一个数N;求1 到n-1与他互为质数的数的个数

     

    欧拉函数可以求解

     

    euler(n)=n*(1-1/p1)(1-1/p2)(1-1/p3)(1-1/p4),,,,,

     

    P1 P2 P3 P4 。。。。。是n的质因数,

     

    比如10的质因数有2 5

     

    所以euler(10)=10*(1-1/2)*(1-1/5)=4

     

    30的质因数 2 3 5

     

    所以 结果是 8

     
    8的质因数是2  所以结果是4(1 3 5 7)
     
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    筛选法求欧拉函数
    const int Max=51;
    int euler[Max];
    void Euler()
    {
        euler[1]=1;
        for(int i=2;i<Max;i++)
            euler[i]=i;
        for(int i=2;i<Max;i++)
            if(euler[i]==i) //筛选掉不是质因数的i;
            for(int j=i;j<Max;j+=i) //保证j都是i的倍数,
            {
                 euler[j]=euler[j]/i*(i-1);// 只要是i的倍数,j就不是质因子,那么euler[j]的值就会改变,不再等于j;
                 cout<<"质因数含有 "<<i<<" 的数"<<j<<",其乘以(1-1/"<<i<<")后的结果是"<<euler[j]<<endl<<endl;
            }
     
    }
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    直接根据欧拉函数的定义
     
     
    int euler(int n)
     {
         int a=n,res=n;
         for(int i=2;i*i<=a;i++) //一个数的质因数不会大于它的平方根
         {
             if(a%i==0) //保证i是质因数
                res=res/i*(i-1); //先乘后除防止溢出
             while(a%i==0)a/=i; //保证i是质因数
         }
         if(a>1)res=res/a*(a-1);
         return res;
     } 
     
     
     
     
     
     
     
     
     
    梦里不知身是客,一晌贪欢。
  • 相关阅读:
    几种连接数据库的OLEDB驱动程序
    Javascript如何访问和处理系统文件
    如何自学Java 经典
    Android Studio 修改 包名
    Android Studio -导入项目 gradle处理
    Android Studio- 把项目提交到SVN中操作方法
    android studio 运行太慢了
    Java多线程 -sleep 用法详解
    Java -native 方法
    Java多线程 -yield用法
  • 原文地址:https://www.cnblogs.com/dccmmtop/p/4840409.html
Copyright © 2011-2022 走看看