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

  C++博客 :: 首頁 ::  :: 聯(lián)系 ::  :: 管理

篩法的性能測試

Posted on 2006-09-02 21:16 chenger 閱讀(705) 評論(0)  編輯 收藏 引用 所屬分類: Programming Stuff
主要是因?yàn)榭戳?a >這篇blog突然想到的。這個篩法求素?cái)?shù)的程序想必每個學(xué)編程的人都寫過,幾乎是最經(jīng)典的算法之一了,雖然似乎沒什么用。但好像的確沒見過對這個古老算法的嚴(yán)格分析。一時好奇,就想把這個算法納入大O的框架之中……不管怎么樣,先拿出代碼再說

require'benchmark'
?
def
sievePerformance(n)
??? r =
Benchmark.realtime() do
??????? sieve =
Array.new(n,true)
??????? sieve[
0..1] = [false,false]
??????? 2.upto(n) do |i|
??????????? if sieve[i]
??????????????? (
2*i).step(n,i) do |j|
??????????????????? sieve[j] =
false
???????????????
end
???????????
end
???????
end
??? end

???
r
end


這段代碼抄自前面Robert C.Martin先生的blog,對篩法作性能測試。初看起來,程序的主體是二重循環(huán),因此算法的復(fù)雜性好像是O(N2)之類的玩意?要么是O(NlnN)?
?
下圖是Ruby自帶的benchmark模塊測量的結(jié)果,上限N從10000到500000,步長20000。Rober C.Martin的文章里也有一張圖,是從1000000到5000000,從圖中可以看到,他電腦的性能遠(yuǎn)勝于我,我要是從1000000到5000000這么跑一遍,花兒都謝了……總之,實(shí)測的結(jié)果是:這個算法的性能基本上是線性的。出于對ruby這樣的解釋型語言的某種不信任,我又把這段程序用C++重寫了一遍,拿C標(biāo)準(zhǔn)庫提供的clock函數(shù)測量時間,結(jié)果在N小于10000000的時候,基本上呈線性,但再往后花費(fèi)的時間就開始超過線性增長了。

下面我給一個比較粗略的分析,解釋為什么這個算法的復(fù)雜度表現(xiàn)為線性。首先,我認(rèn)為主要花費(fèi)時間的是對sieve數(shù)組的讀寫,循環(huán)變量的增加應(yīng)該可以忽略。如果p<N是素?cái)?shù),那么就要進(jìn)入內(nèi)循環(huán)將i的倍數(shù)“挖掉”,也就是對sieve的相應(yīng)元素賦值,要進(jìn)行[N/p]-1次。這樣就得到總共的賦值次數(shù)S為:



其中p為素?cái)?shù)。顯然



數(shù)論中有個Mertens定理可以估計(jì)上面括號中的和式,結(jié)果為



其中c是一個常數(shù)??梢钥吹剑贜很大時和式的主要部分為NlnlnN。而lnlnN是一個增長極慢的函數(shù),lnln105=2.44,lnln109=2.91,幾乎就可以當(dāng)常數(shù)處理(至少在32位無符號整數(shù)范圍內(nèi))。其他的一些項(xiàng),比如循環(huán)變量的步進(jìn),都是O(N),這也就不難理解整個程序的性能是幾乎是O(N)了。




Update:上面的代碼有個很明顯的問題,就是內(nèi)循環(huán)應(yīng)該從i*i開始,而不是2*i,這樣對于比較大的N,性能提高很明顯(接近一半)。另外一個可改進(jìn)的地方是外層循環(huán)的upto(n),可以改為upto(Integer(Math.sqrt(n)),其實(shí)這兩個改動效果是重疊的,任意改一個就差不多了。賦值次數(shù)S應(yīng)為:



結(jié)果為:



可以看到效率的提升是很明顯的,畢竟lnln232也才不到3.1,ln2約為0.7。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲二区免费| 亚洲免费不卡| 激情欧美丁香| 激情成人综合网| 尤物视频一区二区| 亚洲国产欧美另类丝袜| 亚洲激情视频网| 99国产麻豆精品| 宅男精品视频| 香蕉精品999视频一区二区| 久久不见久久见免费视频1| 久久中文久久字幕| 欧美激情第一页xxx| 亚洲精品影视在线观看| 亚洲综合999| 久久亚洲私人国产精品va| 免费精品99久久国产综合精品| 免费观看在线综合色| 国产精品老女人精品视频| 欧美一区二区三区免费看| 欧美一区二区三区日韩| 欧美丰满少妇xxxbbb| 亚洲大胆美女视频| 一本色道**综合亚洲精品蜜桃冫| 亚洲欧美99| 亚洲第一视频| 亚洲午夜精品久久久久久浪潮 | 久久久久国产一区二区| 亚洲第一色中文字幕| 亚洲香蕉网站| 免费观看在线综合色| 国产欧美日韩亚州综合| 亚洲精品一区在线观看香蕉| 久久精品成人欧美大片古装| 亚洲日本一区二区| 久久久久综合网| 国产精品综合不卡av| 99天天综合性| 欧美成人网在线| 先锋影音久久久| 欧美日韩一区二区三区四区五区| 激情欧美一区二区三区| 新67194成人永久网站| 亚洲欧洲免费视频| 久久一区二区三区av| 国产亚洲欧洲| 欧美一区二区三区啪啪| 欧美成人国产一区二区| 免费久久99精品国产自| 亚洲愉拍自拍另类高清精品| 欧美人与性动交a欧美精品| 亚洲国产精品热久久| 久久精品1区| 亚洲视频1区| 欧美特黄a级高清免费大片a级| 亚洲激情偷拍| 免费视频一区二区三区在线观看| 性做久久久久久| 国产精品网站在线观看| 亚洲桃花岛网站| 日韩系列欧美系列| 欧美日韩精品二区第二页| 亚洲精品中文字| 欧美成人午夜激情在线| 另类国产ts人妖高潮视频| 亚洲第一精品福利| 亚洲第一页自拍| 女人香蕉久久**毛片精品| 国自产拍偷拍福利精品免费一| 久久本道综合色狠狠五月| 欧美在线观看一区二区三区| 黑人巨大精品欧美一区二区小视频 | 欧美大片一区| 亚洲一区免费看| 欧美高清视频一区二区| 国产专区综合网| 麻豆成人91精品二区三区| 久久精品五月婷婷| 亚洲精品乱码久久久久| 亚洲美女免费视频| 国产精品理论片在线观看| 久久久91精品国产一区二区精品| 小嫩嫩精品导航| 亚洲国产精品成人精品| 亚洲第一区在线| 国产精品二区三区四区| 欧美在线国产精品| 久久免费视频一区| 亚洲精品欧美在线| 亚洲香蕉成视频在线观看| 韩国av一区二区| 亚洲激情av在线| 国产精品日韩欧美综合| 久热精品视频在线观看| 欧美日韩精品在线观看| 久久精品国产一区二区三区| 欧美xx69| 久久国产精品高清| 免费日韩av片| 香港久久久电影| 久久性天堂网| 亚洲欧美日韩精品久久久久| 久久伊人精品天天| 欧美伊人久久久久久久久影院| 美女啪啪无遮挡免费久久网站| 亚洲一区二区三区四区视频| 久久久视频精品| 性色av一区二区三区在线观看| 玖玖玖国产精品| 久久激情视频免费观看| 欧美日本高清视频| 久久久久国内| 欧美剧在线免费观看网站| 久久久久久穴| 国产精品久久久久婷婷| 欧美激情四色 | 欧美三级在线视频| 裸体丰满少妇做受久久99精品| 欧美午夜精品| 亚洲欧洲一区二区三区在线观看 | 国产区精品在线观看| 亚洲欧洲在线看| 亚洲电影天堂av| 午夜精品在线看| 中文日韩电影网站| 欧美激情第1页| 亚洲二区在线| 亚洲国产激情| 欧美资源在线观看| 久久九九国产精品| 国产精品久久二区| 99热在这里有精品免费| 影音先锋日韩有码| 另类尿喷潮videofree| 久久久www| 国产日韩成人精品| 性欧美暴力猛交另类hd| 亚洲欧美日韩一区在线| 欧美日韩一区综合| 亚洲精品资源| 亚洲一区二区三区在线视频| 西西裸体人体做爰大胆久久久| 欧美亚洲一区在线| 国产精品视频免费在线观看| 亚洲一区二区欧美| 欧美在线一区二区三区| 国产日韩欧美一区二区| 性欧美video另类hd性玩具| 久久久青草婷婷精品综合日韩| 国产精品久线观看视频| 亚洲综合日韩在线| 久久婷婷色综合| 亚洲国产色一区| 欧美另类高清视频在线| 亚洲精品一区二区在线| 午夜精品视频| 国产又爽又黄的激情精品视频 | 亚洲综合视频网| 国产日韩欧美综合| 久久亚洲一区二区三区四区| 亚洲精品国产精品国自产观看 | 欧美国产精品久久| 99riav久久精品riav| 欧美日韩视频不卡| 性欧美暴力猛交69hd| 欧美成人免费全部| 亚洲天堂免费在线观看视频| 国产精品永久免费视频| 久热精品在线视频| 亚洲视频在线观看| 免费久久久一本精品久久区| 99视频在线观看一区三区| 午夜精品免费视频| 久久精品网址| 这里只有精品视频在线| 美女福利精品视频| 亚洲一区综合| 亚洲国产成人在线视频| 欧美日韩在线一区| 久热国产精品| 午夜精品久久久久久久99樱桃| 欧美激情无毛| 久久久xxx| 亚洲尤物视频在线| 亚洲国产一成人久久精品| 国产精品区二区三区日本| 免费观看成人www动漫视频| 亚洲伊人第一页| 亚洲人妖在线| 你懂的国产精品| 欧美在线不卡| 亚洲一区二区三区在线看| 亚洲精品欧美日韩| 伊人久久久大香线蕉综合直播| 国产精品99一区| 欧美激情导航| 欧美激情一区二区三区蜜桃视频| 久久不射网站| 欧美亚洲日本网站| 亚洲一区二区综合|