青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0
<2010年8月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(24)

隨筆分類(332)

隨筆檔案(182)

FRIENDS

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

評論排行榜

求質數 之 除余法 ( 數論 C語言描述 zz )

Posted on 2010-08-07 17:01 MiYu 閱讀(630) 評論(0)  編輯 收藏 引用 所屬分類: ACM ( 數論 ) 、ACM_資料

問題描述

試編寫一個程序,找出 2→N 之間的所有質數(質數的概念請看這里),用盡可能快的方法實現。

問題分析

這個問題可以有兩種解法:一種是用“篩子法”,另一種是從 2→N 逐一檢測出質數。如果要了解“篩法”,請看另一篇文章《求質數 之 篩法》。

現在來介紹第二種方法。用這種方法,最先想到的就是讓從2→N逐一檢查。如果是就顯示出來,如果不是,就繼續檢查下一個直到超出范圍 N。這是正確的做法,但效率卻不高。當然,2 是質數,那么 2 的倍數就不是質數,如果令 i 從 2N,就很冤枉地測試了 4、6、8……這些數?所以第一點改建就是只測試 2 與所有的奇數就足夠了。同理,3 是質數,但6、9、12……這些 3 的倍數卻不是,因此,如果能夠把 2 與 3 的倍數跳過去而不測試,任意連續的 6 個數中,就只會測試 2 個而已。以6n, 6n+1, 6n+2, 6n+3, 6n+4, 6n+5 為例,6n, 6n+2, 6n+4 是偶數,又 6n+3 是 3 的倍數,所以如果 2 與 3 的倍數都不理會,只要測試的數就只留下6n+1和6n+5而已了,因而工作量只是前面想法的 2/6 = 1/3,應該用這個方法編程。

還有個問題,就是如果判斷一個數 i 是否為素數。按素數的定義,也就是只有 1 與本身可以整除,所以可以用 2i-1 去除 i,如果都除不盡,i 就是素數。觀點對,但卻與上一點一樣的笨拙。當 i>2 時,有哪一個數可以被 i-1 除盡的?沒有!為什么?如果 i 不是質數,那么 i=a×b,此地 a 與 b 既不是 i 又不是 1;正因為 a>1,a 至少為 2,因此 b 最多也是 i/2 而已,去除 i 的數用不著是 2i-1,而用 2i/2 就可以了。不但如此,因為 i=a×b,a 與 b 不能大于 sqrt(i),為什么呢?如果 a>sqrt(i),b>sqrt(i),于是 a×b > sqrt(i)*sqrt(i) = i,因此就都不能整除i了。如果i不是質數,它的因子最大就是 sqrt(i);換言之,用 2sqrt(i)去檢驗就行了。

但是,用 2sqrt(i) 去檢驗也是浪費。就像前面一樣,2 除不盡,2 的倍數也除不盡;同理,3 除不盡,3 的倍數也除不盡……最理想的方法就是用質數去除i。

但問題是這些素數從何而來?這比較簡單,可以準備一個數組 prime[],用來存放找到的素數,一開始它里面有 2、3、5。檢查的時候,就用 prime[] 中小于 sqrt(i)的數去除 i 即可,如果都除不盡,i 就是素數,把它放如 prime[] 中,因此 prime[] 中的素數會越來越多,直到滿足個數為止!

不妨用這段說明來編寫這個程序,但是程序設計的時候會有兩個小問題:

  1. 如果只檢查 6n+1 和 6n+5 ?不難發現,它們的距離是4、2、4、2……所以,可以先定義一個變量 gab=4,然后 gab=6-gab;
  2. 比較是不能用 sqrt(i),因為它不精確。舉個例子,i=121,在數學上,sqrt(i) 自然是 11,但計算機里的結果可能是 10.9999999,于是去除的數就是 2、3、5、7,而不含 11,因此 121 就變成質數了。解決這個問題的方法很簡單,不要用開方,用平方即可。例如,如果 p*p<=i,則就用 p 去除 i。而且它的效率比開方高。

程序清單

  1. #include <stdlib.h>  
  2. #include <stdio.h>  
  3. int creat_prime ( int prime[], int n, int total )  
  4. {  
  5.     int i, *p, g = 2;  
  6.     for ( i = 7; i <= n; i += g ) {  
  7.         g = 6 - g;  
  8.         p = prime;  
  9.         while ( (*p) * (*p) <= i && i % (*p) ) {  
  10.             p++;  
  11.         }  
  12.         if ( i % (*p) ) {  
  13.             prime[total++] = i;  
  14.         }  
  15.     }  
  16.     return total;  
  17. }  
  18. int main(void)  
  19. {  
  20.     int prime[30000] = { 2, 3, 5 };  
  21.     int total = 3;     /* 找到素數的個數 */  
  22.     int n = 200000;    /* 要查找的范圍(>=6) */  
  23.     int i;  
  24.     total = creat_prime ( prime, n, total );  
  25.     for ( i = 0; i < total; i++) {  
  26.         printf ( "%d ", prime[i] );  
  27.         if ( i && !(i % 10) )  
  28.             putchar ( '\n' );  
  29.     }  
  30.     putchar ( '\n' );  
  31.     return EXIT_SUCCESS;  
  32. }  

本文轉載自 :


版權聲明

本人的所有原創文章皆保留版權,請尊重原創作品。
轉載必須包含本聲明,保持本文完整,并以超鏈接形式注明原始作者“redraiment”和主站點上的本文原始地址。

聯系方式

我的郵箱,歡迎來信(redraiment@gmail.com
我的Blogger(子清行
我的Google Sites(子清行
我的CSDN博客(夢婷軒
我的百度空間(夢婷軒

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            野花国产精品入口| 中国av一区| 欧美激情视频一区二区三区在线播放 | 欧美日韩另类字幕中文| 免费在线观看成人av| 免费久久99精品国产自| 欧美精品首页| 国产精品久久福利| 国内精品一区二区| 亚洲精品一区二区三区四区高清| 夜夜爽99久久国产综合精品女不卡 | 欧美视频福利| 国产精品久久二区| 黄色成人精品网站| 亚洲狠狠婷婷| 亚洲欧美在线视频观看| 久久精品国产综合精品| 欧美激情一区二区三级高清视频| 99精品黄色片免费大全| 欧美在线视频免费播放| 美女国产一区| 国产精品日韩精品欧美精品| 亚洲电影有码| 欧美一区二区精品久久911| 欧美18av| 亚洲一区二区在线免费观看视频| 久久先锋资源| 国产精品系列在线播放| 亚洲精品美女久久久久| 欧美一区二区在线播放| 最新亚洲电影| 欧美一区久久| 欧美午夜欧美| 亚洲激情视频| 久久久一区二区| 一卡二卡3卡四卡高清精品视频| 久久精品国产亚洲aⅴ| 欧美日韩在线播放一区二区| 亚洲电影免费观看高清完整版在线观看 | 亚洲精品欧洲精品| 久久人体大胆视频| 亚洲性色视频| 欧美日韩一本到| 亚洲精品免费一二三区| 久久亚洲电影| 篠田优中文在线播放第一区| 欧美午夜寂寞影院| 一区二区三区日韩在线观看| 亚洲福利视频一区| 久久伊人一区二区| 国产一区二区剧情av在线| 亚洲一区观看| 99精品国产在热久久| 欧美日本免费一区二区三区| 亚洲国产另类久久久精品极度| 久久女同精品一区二区| 午夜亚洲精品| 国内精品久久久| 久久久国产亚洲精品| 性亚洲最疯狂xxxx高清| 国产精品一区视频| 国产一区99| 久久激情中文| 久久se精品一区二区| 国内精品久久久久久久果冻传媒| 欧美中文字幕| 久久精品国产清自在天天线| 狠狠色丁香婷婷综合| 久久免费视频在线观看| 久久综合成人精品亚洲另类欧美| 尤物在线精品| 亚洲国产精品va| 欧美激情中文字幕在线| 中文精品99久久国产香蕉| 一区二区三区精品视频在线观看| 国产精品av一区二区| 午夜亚洲性色福利视频| 欧美在线影院| 亚洲高清资源| av成人动漫| 国产一区二区三区在线观看网站| 噜噜噜在线观看免费视频日韩 | 亚洲精品乱码久久久久久蜜桃91| 欧美欧美午夜aⅴ在线观看| 亚洲一区久久久| 欧美一级黄色录像| 亚洲国产福利在线| 999在线观看精品免费不卡网站| 欧美午夜激情小视频| 久久久久一区二区三区| 欧美成人中文字幕| 亚洲欧美在线aaa| 免费在线成人av| 欧美在线观看视频| 欧美黄色成人网| 欧美一区二区三区日韩| 噜噜噜噜噜久久久久久91| 亚洲无亚洲人成网站77777| 亚洲欧洲99久久| 日韩一级免费观看| 午夜在线精品偷拍| 99国产精品视频免费观看一公开| 亚洲欧美卡通另类91av| 亚洲国产一区二区a毛片| 亚洲特级毛片| 日韩天堂在线视频| 久久久xxx| 性色av一区二区三区在线观看| 久久综合久久综合九色| 午夜精品一区二区三区电影天堂| 久久综合网hezyo| 性做久久久久久免费观看欧美| 久久久一区二区三区| 午夜精品久久久久久久99樱桃 | 欧美成在线视频| 久久久九九九九| 国产精品久久久久久户外露出| 榴莲视频成人在线观看| 国产免费一区二区三区香蕉精| 亚洲高清免费在线| 黄色av日韩| 欧美一区二区成人6969| 欧美大片一区二区三区| 亚洲伊人观看| 欧美一区二区三区免费视| 亚洲综合欧美日韩| 尤物yw午夜国产精品视频| 亚洲免费一在线| 99热这里只有精品8| 欧美中文在线观看国产| av不卡在线看| 欧美高清在线| 亚洲第一成人在线| 黄页网站一区| 久久精品一区二区国产| 久久成人免费| 国产精品有限公司| 一区二区三区**美女毛片| 99国产欧美久久久精品| 免费看黄裸体一级大秀欧美| 久久综合伊人77777蜜臀| 国产免费成人av| 欧美在线观看一二区| 久久激情五月激情| 国产一区二区三区久久悠悠色av | 欧美成人a视频| 国产亚洲欧洲一区高清在线观看 | 久久精品国产99精品国产亚洲性色| 欧美日韩午夜剧场| 在线综合视频| 性伦欧美刺激片在线观看| 国产精品久久久久久久久久久久久| 一区二区三区精品在线| 亚洲影院免费| 国产亚洲欧美一区二区三区| 久久精品亚洲乱码伦伦中文 | 欧美另类videos死尸| 99精品视频免费观看| 亚洲综合电影| 国产无一区二区| 蜜臀99久久精品久久久久久软件 | 怡红院精品视频| 免费成人黄色片| 亚洲精品激情| 久久福利一区| 日韩视频三区| 国产伦精品一区二区三区高清| 欧美一区二区在线免费播放| 免费看亚洲片| 亚洲一区国产精品| 午夜精品久久久久久久久久久久 | 欧美激情亚洲视频| 亚洲欧美国产精品va在线观看| 国产日产欧产精品推荐色| 久久先锋资源| 亚洲欧美日韩一区二区三区在线 | 欧美一区二区三区免费看| 狠狠入ady亚洲精品| 欧美人与性动交cc0o| 欧美一级片在线播放| 亚洲国产日韩综合一区| 久久精品成人一区二区三区 | 亚洲私人影院| 韩国欧美一区| 国产精品白丝av嫩草影院| 久久久夜精品| 欧美一区二区三区视频在线 | 性欧美大战久久久久久久久| 亚洲福利专区| 国产日韩亚洲欧美精品| 欧美精品videossex性护士| 欧美一区在线视频| 中文在线一区| 亚洲精品一区中文| 免费日韩av电影| 欧美专区在线观看| 亚洲主播在线播放| 一区二区三区高清不卡| 亚洲国产一成人久久精品| 国内精品一区二区|