• <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>
            隨筆 - 70  文章 - 160  trackbacks - 0

            公告:
            知識(shí)共享許可協(xié)議
            本博客采用知識(shí)共享署名 2.5 中國(guó)大陸許可協(xié)議進(jìn)行許可。本博客版權(quán)歸作者所有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意不得隨機(jī)刪除文章任何內(nèi)容,且在文章頁面明顯位置給出原文連接,否則保留追究法律責(zé)任的權(quán)利。 具體操作方式可參考此處。如您有任何疑問或者授權(quán)方面的協(xié)商,請(qǐng)給我留言。

            常用鏈接

            留言簿(8)

            隨筆檔案

            文章檔案

            搜索

            •  

            積分與排名

            • 積分 - 179080
            • 排名 - 147

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            The Sieve of Eratosthens
            愛拉托遜斯篩選法


            (原創(chuàng)鏈接:http://www.wutianqi.com/?p=264[2:23]
            思想:對(duì)于不超過n的每個(gè)非負(fù)整數(shù)P,刪除2*P, 3*P…,當(dāng)處理

            完所有數(shù)之后,還沒有被刪除的就是素?cái)?shù)。

            若用vis[i]==1表示已被刪除,則代碼如下:
            —————————————————–
            代碼一:

            1memset(vis, 0sizeof(vis));
            2for(int i = 2; i <= 100; i++)
            3    for(int j = i*2; j <= 100; j += i)
            4        vis[j] = 1;


            上面的代碼效率已經(jīng)很高了。
            但還可以繼續(xù)優(yōu)化。
            看一個(gè)改進(jìn)的代碼:
            ——————————————————
            代碼二:

             1int m = sqrt(double(n+0.5));
             2 
             3for(int i = 2; i <= m; i++)
             4    if(!vis[i])
             5    {
             6        prime[c++= i;
             7        for(int j = i*i; j <= n; j += i)
             8        {
             9            vis[j] = 1;
            10        }

            11    }



            ——————————————————
            先分析代碼一:
            這個(gè)代碼就是簡(jiǎn)單的將Eratosthenes篩選法描述出來。不用多說。
            分析代碼二:
            考慮幾點(diǎn):
            1.為何從i=2~m?
            因?yàn)橄旅娴膉是從i*i開始的。
            2.為何j從i*i開始?
            因?yàn)槭紫仍趇=2時(shí),偶數(shù)都已經(jīng)被刪除了。
            其次,“對(duì)于不超過n的每個(gè)非負(fù)整數(shù)P”, P可以限定為素?cái)?shù),
            為什么?
            因?yàn)椋?i 執(zhí)行到P時(shí),P之前所有的數(shù)的倍數(shù)都已經(jīng)被刪除,若P

            沒有被刪除,則P一定是素?cái)?shù)。
            而P的倍數(shù)中,只需看:
            (p-4)*p, (p-2)*p, p*p, p*(p+2), p*(p+4)
            (因?yàn)镻為素?cái)?shù),所以為奇數(shù),而偶數(shù)已被刪除,不需要考慮p*(p

            -1)等)(Tanky Woo的程序人生)
            又因?yàn)?p-4)*p 已在 (p-4)的p倍中被刪去,故只考慮:
            p*p, p*(p+2)….即可
            這也是i只需要從2到m的原因。
            當(dāng)然,上面 p*p, p*(p+2)…的前提是偶數(shù)都已經(jīng)被刪去,而代碼

            二若改成 j += 2*i ,則沒有除去所有偶數(shù),所以要想直接 加2*i

            。只需在代碼二中memset()后面加:
            for(int i = 4; i <= n; i++)
            if(i % 2 == 0)
            vis[i] = 1;
            這樣,i只需從3開始,而j每次可以直接加 2*i.
            ------------------------------------------------------
            這里用代碼二給大家一個(gè)完整的代碼:

             1//版本二
             2//Author: Tanky Woo
             3//Blog: www.wutianqi.com
             4 
             5#include <stdio.h>
             6#include <string.h>
             7#include <math.h>
             8int vis[100];
             9int prime[100];
            10int c = 0;
            11int n;
            12int main()
            13{
            14    scanf("%d"&n);
            15    int cnt = 1;
            16 
            17    memset(vis, 0sizeof(vis));
            18    int m = sqrt(double(n+0.5));
            19 
            20    for(int i = 2; i <= m; i++)
            21        if(!vis[i])
            22        {
            23            prime[c++= i;
            24            for(int j = i*i; j <= n; j += i)
            25            {
            26                vis[j] = 1;
            27                //printf("%d\n", j);
            28            }

            29        }

            30 
            31    for(int i = 2; i < n; i++)
            32    {
            33        if(vis[i] == 0)
            34        {
            35            printf("%d ", i);
            36            cnt++;
            37            if(cnt % 10 == 0)
            38                printf("\n");
            39        }

            40    }

            41    printf("\ncnt = %d\n", cnt);
            42    return 0;
            43}



            完畢。


            歡迎大家和我交流。(我的博客:http://www.wutianqi.com/)




            posted on 2010-08-04 13:55 Tanky Woo 閱讀(1162) 評(píng)論(1)  編輯 收藏 引用

            FeedBack:
            # re: The Sieve of Eratosthens(愛拉托遜斯篩選法)分析  2010-08-04 15:06 schindlerlee
            搜 線性篩法  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久久久狠狠丁香| 97香蕉久久夜色精品国产| 99久久婷婷国产综合亚洲| 国产∨亚洲V天堂无码久久久| 精品国产一区二区三区久久久狼| 国产精品久久久久久吹潮| 国产激情久久久久影院| 亚洲AV伊人久久青青草原| 香蕉久久夜色精品升级完成| 久久国产亚洲精品麻豆| 久久久国产亚洲精品| 国产一区二区三区久久精品| 四虎亚洲国产成人久久精品| 成人久久精品一区二区三区| 久久www免费人成看国产片| 综合久久国产九一剧情麻豆| 欧美激情精品久久久久| 久久伊人五月丁香狠狠色| 亚洲国产精品久久久久| 久久无码人妻一区二区三区| 国产精品欧美久久久久无广告| 亚洲国产另类久久久精品| 99国内精品久久久久久久| 久久亚洲欧美国产精品| 久久精品国产精品亚洲艾草网美妙| 久久无码专区国产精品发布| 久久午夜综合久久| 色偷偷888欧美精品久久久| 亚洲午夜无码久久久久| 亚洲精品国产第一综合99久久| 91亚洲国产成人久久精品网址 | 人妻少妇精品久久| 色噜噜狠狠先锋影音久久| 国产成人久久AV免费| 中文字幕乱码久久午夜| 久久精品国产男包| 久久无码AV一区二区三区| 亚洲国产成人久久综合区| 无码8090精品久久一区 | 久久国产亚洲精品麻豆| 国产精品久久永久免费|