91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

歐拉函數有什么用

發布時間:2022-01-14 17:26:46 來源:億速云 閱讀:148 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關歐拉函數有什么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

題解:就是求n以內 所有互素的數 的組合數! 即n以內所有整數的歐拉函數之和!

歐拉函數知識點 可以參考白書。

//	2478	Accepted	4084K	235MS	C++	620B	
//	2478	Accepted	8000K	282MS	C++	735B	
#include <iostream>//詳細可以參見 白書!
#include<cstdio>
#include<cstring>
using namespace std;
#define N 1000010
int phi[N];
void Eula()
{
    int i,j;
    memset(phi,0,sizeof(phi));//篩法 求出N以內的所有 n以內的互素數!
    for(i=2;i<=N;i++)//素數從2開始
    {
        if(!phi[i])
        {
            for(j=i;j<=N;j+=i)
            {
                if(!phi[j]) phi[j]=j;//賦給該數 素因子分解后 它的最小素因子!
                phi[j]=phi[j]/i*(i-1);//后面每一個素因子可以組成的數 都用公式刷新下該數的 歐拉數!
            }
        }
    }
    //for(i=2;i<=N;i++)phi[i]+=phi[i-1]; 第二種方法可以把所有答案打好表!
}
int main()
{
    Eula();
    int n,i;
    __int64 sum;
    while(scanf("%d",&n),n)
    {
        sum=0;
        for(i=2;i<=n;i++)
            sum+=phi[i];
        printf("%I64d\n",sum);
    }
    return 0;
}

上面是打表的方法--適用于多數據 而數據小;

以下為求單個 數的歐拉函數--適用于大數據 小規模;

#include<stdio.h>
long long phi(long long a)
{
long long temp=a;
for(long long i=2;i*i<=a;i++)
if(a%i==0)
{
while(!(a%i))a/=i;  //該數有此素因子,先除完.
temp=temp/i*(i-1);  //利用公式 n/(1-1/p);
}
if(a!=1)  //最后a不是1 就是一個素數.
temp=temp/a*(a-1);//再利用公式除一下就ok!
return temp;
} 
int main() 
{
long long a,b,c;
while(scanf("%lld",&a)!=EOF)
printf("%lld\n",phi(a));
return 0;
}

關于“歐拉函數有什么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節
推薦閱讀:
  1. 歐拉函數
  2. DFS序,歐拉序

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

砚山县| 修文县| 贵州省| 太仆寺旗| 湄潭县| 璧山县| 建宁县| 新沂市| 酉阳| 阿勒泰市| 桓台县| 财经| 鄢陵县| 济阳县| 克拉玛依市| 海宁市| 广平县| 延津县| 城固县| 达拉特旗| 醴陵市| 农安县| 郑州市| 凯里市| 尼勒克县| 曲阳县| 昌黎县| 萝北县| 磐安县| 黄浦区| 武邑县| 故城县| 简阳市| 九江市| 唐海县| 桐柏县| 怀安县| 沂源县| 沭阳县| 资阳市| 嘉义县|