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

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)化。
看一個改進的代碼:
——————————————————
代碼二:
  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
- -||| 我無語....
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美福利视频在线观看| 亚洲女ⅴideoshd黑人| 久久婷婷久久| 久久精品中文字幕一区| 亚洲福利av| 亚洲精品一区二区三区在线观看| 欧美精品在线观看一区二区| 亚洲私人影院在线观看| 亚洲欧美在线看| 激情欧美一区二区三区| 亚洲国产福利在线| 欧美剧在线免费观看网站| 亚洲视频精选| 亚洲欧美一区二区三区在线 | 亚洲精品一区二区三区av| 欧美性一二三区| 久久久一区二区| 美女久久网站| 欧美日韩综合视频网址| 久久蜜桃资源一区二区老牛 | 久久国产一区二区三区| 一区二区亚洲精品| 亚洲精品婷婷| 国产综合精品| 99精品久久| 一区二区三区在线免费观看| 亚洲精品久久久久久久久久久久久| 国产精品成人午夜| 女人香蕉久久**毛片精品| 欧美日韩精品欧美日韩精品一| 欧美在线观看视频| 欧美日韩国产在线播放网站| 麻豆精品网站| 国产精品自在欧美一区| 亚洲人成人一区二区在线观看 | 欧美不卡视频一区| 欧美一区综合| 国产精品chinese| 欧美国产丝袜视频| 国产亚洲精品高潮| 一区二区三区欧美亚洲| 亚洲欧洲三级| 久久综合久色欧美综合狠狠| 亚洲欧美日韩区| 欧美日韩国产成人| 亚洲大胆人体视频| 禁久久精品乱码| 性刺激综合网| 久久都是精品| 国产欧美日韩综合一区在线观看 | 午夜精品福利视频| 欧美精品亚洲二区| 亚洲福利在线视频| 在线观看av一区| 久久久久9999亚洲精品| 久久精品91| 国产亚洲成精品久久| 中日韩高清电影网| 亚洲无人区一区| 欧美日韩高清区| 亚洲日本激情| 日韩亚洲视频在线| 欧美国产精品人人做人人爱| 欧美国产综合| 亚洲精品欧美日韩| 欧美精品一区二区视频| 亚洲理论电影网| 中文在线不卡视频| 国产精品www色诱视频| 中文亚洲免费| 久久er精品视频| 国语自产在线不卡| 久久美女性网| 亚洲高清不卡av| 亚洲精品一区在线| 欧美日韩国产成人在线观看| 日韩视频在线一区二区| 亚洲天堂免费观看| 国产日韩欧美一区在线| 久久狠狠婷婷| 一本到12不卡视频在线dvd| 欧美国产视频日韩| 一区二区三区高清视频在线观看| 午夜精品福利一区二区三区av| 国产精品久久999| 久久爱另类一区二区小说| 欧美 日韩 国产在线| 亚洲美女中文字幕| 国产精品一区二区视频| 久久国产精品第一页| 亚洲福利在线看| 欧美一级淫片播放口| 在线观看一区欧美| 欧美日韩ab片| 性做久久久久久免费观看欧美| 老司机午夜精品视频在线观看| 亚洲精品乱码久久久久久黑人| 欧美日韩在线播放三区| 欧美一区二区视频在线观看2020| 亚洲国产欧洲综合997久久| 亚洲午夜高清视频| 国模大胆一区二区三区| 欧美日韩成人| 久久av一区二区三区漫画| 亚洲精品免费一二三区| 久久精品中文字幕免费mv| 99成人精品| 国产一级久久| 欧美午夜宅男影院在线观看| 久久亚洲精品视频| 午夜精品美女久久久久av福利| 亚洲国产欧美一区二区三区丁香婷| 亚洲欧美日韩人成在线播放| 91久久国产综合久久91精品网站| 国产精品一区免费在线观看| 欧美电影免费观看| 久久激情久久| 亚洲一区二区三区四区五区午夜| 亚洲电影欧美电影有声小说| 久久久777| 亚洲在线第一页| 日韩一区二区精品视频| 在线播放日韩| 狠狠久久五月精品中文字幕| 欧美日韩在线精品| 欧美激情精品久久久久久黑人| 久久久999国产| 香蕉久久夜色精品国产使用方法| 99国产精品自拍| 亚洲国产成人在线播放| 欧美成人一区二区三区在线观看| 久久精品国产999大香线蕉| 亚洲在线第一页| 亚洲性感美女99在线| 一区二区91| 日韩亚洲视频在线| 妖精成人www高清在线观看| 亚洲黄色天堂| 亚洲精品免费在线播放| 亚洲国内自拍| 日韩视频亚洲视频| 亚洲美女免费视频| 亚洲免费黄色| 一区二区三区 在线观看视| 夜夜嗨av色一区二区不卡| 亚洲精品国产精品国自产观看浪潮| 在线精品福利| 亚洲日本电影在线| 亚洲美女性视频| 亚洲视频一二| 亚洲男人的天堂在线| 亚洲男人天堂2024| 久久久高清一区二区三区| 久久午夜色播影院免费高清| 久久综合给合| 亚洲国产精品第一区二区三区 | 亚洲素人一区二区| 亚洲人www| 国产精品亚洲一区| 国产片一区二区| 在线观看一区二区精品视频| 亚洲国产精品一区二区第四页av | 久久免费视频观看| 欧美成人影音| 一本色道久久99精品综合 | 亚洲最新在线视频| 亚洲伊人网站| 久久精品国产一区二区电影| 免费一级欧美片在线观看| 欧美另类高清视频在线| 国产精品毛片a∨一区二区三区|国| 国产精品亚洲网站| 亚洲国产成人av好男人在线观看| 一区二区三区三区在线| 久久国产精品久久久久久| 亚洲国产99| 午夜精品国产| 欧美激情中文字幕一区二区| 国产精品毛片一区二区三区 | 国产欧美日韩另类一区| 亚洲国产视频直播| 亚洲免费视频网站| 欧美国产欧美亚洲国产日韩mv天天看完整| 最新国产精品拍自在线播放| 午夜在线视频观看日韩17c| 男男成人高潮片免费网站| 国产精品日韩一区二区| 亚洲黄色视屏| 久久视频国产精品免费视频在线| 亚洲欧洲免费视频| 久久超碰97中文字幕| 国产精品a久久久久| 亚洲精品乱码久久久久久按摩观| 久久精品国产96久久久香蕉| 亚洲麻豆av| 欧美成人tv| 伊人久久亚洲热| 欧美与欧洲交xxxx免费观看| 亚洲精品免费一二三区| 美女黄色成人网|