找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
伊莉需要你的贊助和支持搞笑、娛樂、精彩的影片讓你看安全提問(回答) 和 永久尊貴會員 事宜
ge火影3dsiromg鬼滅之刃adobe
タワーオ鬥破蒼穹永平 回エロいも艾爾登大富翁1110902

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

[簡]成為名留歷史的壞

[繁]嘆氣的亡靈想隱退

[繁]精靈幻想記 第二

[繁]嘆氣的亡靈想隱退

[繁]最狂輔助職業【話

珠海體育中心 越野車
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1101|回復: 0
打印上一主題下一主題

[教學]階乘的質因數分解-ACM 160[複製鏈接]

hoare 該用戶已被刪除
跳轉到指定樓層
樓主
發表於 2013-11-10 05:41 PM|只看該作者|正序瀏覽
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。
表示階乘的其中一種方法是去紀錄每一個質因數出現的頻率。例如 825 這個值, 可以用數字序列 (0 1 2 0 1), 來表示 0 個 2, 1 個 3, 2 個 5, 0 個 7, 1 個 11。寫一個程式讀入一個數字 N (2<=N<=100), 算出階乘結果,以之前的方式來表示這個階乘。

直覺的做法是先算出階乘,再求質因數分解,但即使是使用long long也無法算出100!,因為會overflow,那如果分開求質因數分解,如100!=100*99*98*.....*1,先算100的質因數分解,然後99, 依此類推,最後再統計起來就可以了,似乎是可行的,但其實還有一個偷雞的方法,先建一個質數表,然後用每個質數去代,例如我們先來觀察10!的2質因數個數要怎麼算,10!=10*9*8*7*6*5*4*3*2*1,其中2, 4,6,8 ,10可以被2整除,4,8可以被2^2整除,8可以被2^3整除,所以2的資因數個數等於5+2+1=8,可以寫成以下的演算法。
  1.     int prime_factor_count = 0;
  2.     int d = 0;
  3.     for(i=0; i<PRIME_TABLE_SIZE&& prime_table[i] <= n; ++i){
  4.         d = prime_table[i];
  5.         while(d <= n){
  6.             prime_factor_count += n/d;
  7.             d *= prime_table[i];
  8.         }
  9.         cout<<"Number of times of prime "<<prime_table[i]<<"is "<<prime_factor_count<<endl;
  10.         prime_factor_count = 0;
  11.     }
複製代碼
如此一來要求解100!的質因數分解也是瞬間的事而已。

...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0
如果你忘記伊莉的密碼,請在登入時按右邊出現的 '找回密碼'。輸入相關資料後送出,系統就會把密碼寄到你的E-Mail。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部