码迷,mamicode.com
首页 > 其他好文 > 详细

【转】欧拉函数

时间:2016-08-13 19:30:22      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

链接:http://www.cnblogs.com/yefeng1627/archive/2013/01/02/2842492.html

 

欧拉函数直接计算公式

  欧拉函数的定义: E(N)= (  区间[1,N-1] 中与 N 互质的整数个数).

  对于 积性函数 F(X*Y),当且仅当 GCD(X,Y)= 1 时, F(X*Y) = F(X)* F(Y)

  任意整数可因式分解为如下形式:

   技术分享     其中( p1, p2 ... pk 为质数, ei 为次数 )  

  所以

    技术分享

  因为 欧拉函数 E(X)为积性函数, 所以

    技术分享 

  对于  技术分享  , 我们知道 因为pi 为质数,所以 [ 1, pi-1 ] 区间的数都与 pi 互质

  对于 区间[ 1, 技术分享  ]  ,共有 技术分享 个数, 因为 技术分享 只有一个质因子,

  所以与 技术分享 约数大于1 的必定包含 质因子 技术分享  , 其数量为 技术分享  

  

    所以   技术分享   

  又 E(N)为积性函数,所以可得 :

   技术分享 

  又因为  技术分享     其中( p1, p2 ... pk 为质数, ei 为次数 )  

   技术分享      但是此计算公式,除法过多,所以计算速度较慢

 

  在程序中利用欧拉函数如下性质,可以快速求出欧拉函数的值 ( P为N的质因子 )

    若(N%P==0 && (N/P)%P==0) 则有:E(N)=E(N/P)*P;
 
    若(N%P==0 && (N/P)%P!=0) 则有:E(N)=E(N/P)*(P-1);

 

求单个数的欧拉函数:

long long eular(long long n)
{
    int i;
    long long ans=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 eular[MAXN+1];
void getEular()
{
    int i,j;
    memset(eular,0,sizeof(eular));
    eular[1]=1;
    for(i=2;i<=MAXN;i++)
    {
        if(!eular[i])
            for(j=i;j<=MAXN;j+=i)
            {
                if(!eular[j])
                    eular[j]=j;
                eular[j]=eular[j]/i*(i-1);
            }
    }
}

线性筛(同时得到欧拉函数和素数表)

bool check[MAXN+10];
int phi[MAXN+10];
int prime[MAXN+10];
int tot;
void phi_and_prime_table(int N)
{
    int i,j;
    memset(check,false,sizeof(check));
    phi[1]=1;
    tot=0;
    for(i=2;i<=N;i++)
    {
        if(!check[i])
        {
            prime[tot++]=i;
            phi[i]=i-1;
        }
        for(j=0;j<tot;j++)
        {
            if(i*prime[j]>N)break;
            check[i*prime[j]]=true;
            if(i%prime[j]==0)
            {
                phi[i*prime[j]]=phi[i]*prime[j];
                break;
            }
            else
                phi[i*prime[j]]=phi[i]*(prime[j]-1);
        }
    }
}

  

【转】欧拉函数

标签:

原文地址:http://www.cnblogs.com/vwqv/p/5768571.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!