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

伊莉討論區

搜索
伊莉需要你的贊助和支持儲值後自動升級用戶組搞笑、娛樂、精彩的影片讓你看
人妻mgmega 無三上悠亜航海王一拳超人julia
winter田chop sti寶可夢 天蠶土豆神農道君黑獸

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

[繁]不時輕聲地以俄語

[繁]靠廢柴技能【狀態

[簡]義妹生活12- (完)

[繁]我的英雄學院 第

[繁]杖與劍的魔劍譚11

2024年10月新番『孤單
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1067|回復: 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
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。

使用道具檢舉

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

Powered by Discuz!

© Comsenz Inc.

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