• <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>

            ACM___________________________

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

            常用鏈接

            留言簿(24)

            隨筆分類(332)

            隨筆檔案(182)

            FRIENDS

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            轉(zhuǎn)載文章 : 轉(zhuǎn)載自Tanky Woo 的程序人生 , <------- 請大家多多支持奮斗哥哈


            The Sieve of Eratosthees
            愛拉托遜斯篩選法思想:對于不超過n的每個非負(fù)整數(shù)P,刪除2*P, 3*P…,當(dāng)處理

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

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

            1. memset(vis, 0, sizeof(vis));
            2. for(int i = 2; i <= 100; i++)
            3. for(int j = i*2; j <= 100; j += i)
            4.   vis[j] = 1;
            復(fù)制代碼
            上面的代碼效率已經(jīng)很高了。
            但還可以繼續(xù)優(yōu)化。
            看一個改進(jìn)的代碼:
            ——————————————————
            代碼二:
            1. int m = sqrt(double(n+0.5));

            2. for(int i = 2; i <= m; i++)
            3. if(!vis[i])
            4. {
            5.   prime[c++] = i;
            6.   for(int j = i*i; j <= n; j += i)
            7.   {
            8.    vis[j] = 1;
            9.   }
            10. }
            復(fù)制代碼
            ——————————————————
            先分析代碼一:
            這個代碼就是簡單的將Eratosthenes篩選法描述出來。不用多說。
            分析代碼二:
            考慮幾點:
            1.為何從i=2~m?
            因為下面的j是從i*i開始的。
            2.為何j從i*i開始?
            因為首先在i=2時,偶數(shù)都已經(jīng)被刪除了。
            其次,“對于不超過n的每個非負(fù)整數(shù)P”, P可以限定為素數(shù),
            為什么?
            因為,在 i 執(zhí)行到P時,P之前所有的數(shù)的倍數(shù)都已經(jīng)被刪除,若P

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

            -1)等)
            又因為(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 = 1;
            這樣,i只需從3開始,而j每次可以直接加 2*i.
            ——————————————————
            這里用代碼二給大家一個完整的代碼:
            1. //版本二
            2. //Author: Tanky Woo
            3. //BBS:www.cppleyuan.com
            4. #include <stdio.h>
            5. #include <string.h>
            6. #include <math.h>
            7. int vis[100];
            8. int prime[100];
            9. int c = 0;
            10. int n;
            11. int main()
            12. {
            13.         scanf("%d", &amp;n);
            14.         int cnt = 1;

            15.         memset(vis, 0, sizeof(vis));
            16.         int m = sqrt(double(n+0.5));

            17.         for(int i = 2; i <= m; i++)
            18.                 if(!vis[i])
            19.                 {
            20.                         prime[c++] = i;
            21.                         for(int j = i*i; j <= n; j += i)
            22.                         {
            23.                                 vis[j] = 1;
            24.                                 //printf("%d\n", j);
            25.                         }
            26.                 }

            27.         for(int i = 2; i < n; i++)
            28.         {
            29.                 if(vis[i] == 0)
            30.                 {
            31.                         printf("%d ", i);
            32.                         cnt++;
            33.                         if(cnt % 10 == 0)
            34.                                 printf("\n");
            35.                 }
            36.         }
            37.         printf("\ncnt = %d\n", cnt);
            38.         return 0;
            39. }
            復(fù)制代碼
            完畢。

            歡迎大家和我交流。 

            轉(zhuǎn)載文章 : 轉(zhuǎn)載自Tanky Woo 的程序人生

            Feedback

            # re: The Sieve of Eratosthees ( 愛拉托遜斯篩選法 數(shù)論 篩法 )  回復(fù)  更多評論   

            2010-08-07 20:45 by Tanky Woo
            Orz奮斗哥

            # re: The Sieve of Eratosthees ( 愛拉托遜斯篩選法 數(shù)論 篩法 )  回復(fù)  更多評論   

            2010-08-07 22:41 by MiYu
            - -||| 我無語....
            亚洲国产精品一区二区久久| 久久久久97国产精华液好用吗| 久久人妻少妇嫩草AV无码专区| 久久精品极品盛宴观看| 精品无码人妻久久久久久| 国产精品久久久久一区二区三区| 99热热久久这里只有精品68| 97久久香蕉国产线看观看| 亚洲国产精品一区二区久久| 国产欧美久久久精品| 国产巨作麻豆欧美亚洲综合久久| 77777亚洲午夜久久多喷| 久久精品麻豆日日躁夜夜躁| 久久超碰97人人做人人爱| 久久99精品久久久久久久不卡 | 久久久久亚洲AV无码观看| 狠狠色丁香婷综合久久| 久久青草国产精品一区| 超级碰碰碰碰97久久久久| 国产精品久久成人影院| A级毛片无码久久精品免费| 久久久久九九精品影院| 国产精品久久久久免费a∨| 久久久久AV综合网成人| 久久精品视频网| 亚洲国产精品成人久久蜜臀| 久久伊人精品青青草原高清| 国产成人久久久精品二区三区| 婷婷久久综合九色综合绿巨人 | 欧洲精品久久久av无码电影| 久久人人爽人爽人人爽av| 精品免费久久久久久久| 国产999精品久久久久久| 热久久最新网站获取| 国产精品久久久亚洲| 久久一区二区三区免费| 久久精品国产亚洲AV电影| 日产久久强奸免费的看| 久久777国产线看观看精品| 久久久久久免费视频| 狠狠人妻久久久久久综合蜜桃|