快速求解歐拉函數

來源:互聯網
上載者:User

原始碼:

void get(){  for(int i=2;i<1001000;i++){      num[i]=1;      euler[i]=i;  }  for(int i=2;i<1001000;i++)   {       if(num[i])       for(int j=i;j<1001000;j+=i)       {           num[j]=0;           euler[j]=euler[j]/i*(i-1);       }   }}

剛開始的時候,第一個迴圈的判斷條件是i*i<1001000,後來發現這樣的話,不能將j的所有質因子都找到,他這樣只枚舉了sqrt(1001000)的素數。

搞得我調了一段時間。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.