The Sieve of Eratosthees ( 愛拉托遜斯篩選法 數(shù)論 篩法 )
Posted on 2010-08-07 16:37 MiYu 閱讀(733) 評(píng)論(2) 編輯 收藏 引用 所屬分類: ACM ( 數(shù)論 ) 、ACM_資料
|
轉(zhuǎn)載文章 : 轉(zhuǎn)載自Tanky Woo 的程序人生 , <------- 請(qǐng)大家多多支持奮斗哥哈
但還可以繼續(xù)優(yōu)化。 看一個(gè)改進(jìn)的代碼: —————————————————— 代碼二:
先分析代碼一: 這個(gè)代碼就是簡(jiǎn)單的將Eratosthenes篩選法描述出來(lái)。不用多說。 分析代碼二: 考慮幾點(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)等) 又因?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 = 1; 這樣,i只需從3開始,而j每次可以直接加 2*i. —————————————————— 這里用代碼二給大家一個(gè)完整的代碼:
歡迎大家和我交流。 轉(zhuǎn)載文章 : 轉(zhuǎn)載自Tanky Woo 的程序人生 |


