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

            雁過(guò)無(wú)痕

            《編程之美》讀書(shū)筆記22:    1.16  24點(diǎn)游戲(補(bǔ)充)

             

            給定n個(gè)數(shù),能否只通過(guò)加減乘除計(jì)算得到24

            書(shū)上給出的最后一種解法,通過(guò)使用集合記錄中間結(jié)果來(lái)減少冗余計(jì)算。本以為,程序會(huì)占用大量的內(nèi)存,用一個(gè)極端的例子(13, 773, 28, 98, 731, 1357,973572467個(gè)數(shù))測(cè)試了一下實(shí)現(xiàn)的程序,發(fā)現(xiàn)程序竟然占用了1G以上的內(nèi)存(無(wú)論集合的實(shí)現(xiàn)采用STL中的set還是unordered_set),但后來(lái),取7個(gè)均在113之間的數(shù),再重新測(cè)試了下發(fā)現(xiàn),程序所占用的內(nèi)存比想像的小的多,也就幾兆。

            對(duì)數(shù)值都在113之間的n個(gè)數(shù)的所有組合進(jìn)行判斷。在n等于4時(shí),實(shí)現(xiàn)的程序約過(guò)1秒就給出了結(jié)果,而n等于5時(shí),程序要運(yùn)行58秒,效率實(shí)在差,可以通過(guò)這幾方面優(yōu)化:

            ① 保存每個(gè)集合的子集合的編號(hào):

            對(duì)給定的n,共有12^n – 1個(gè)集合,每個(gè)集合的子集合編號(hào)是固定的,但原程序每計(jì)算一個(gè)n個(gè)數(shù)的組合,都要對(duì)這些子集合編號(hào)計(jì)算一遍,可以保存每個(gè)集合的子集合編號(hào),減少大量的重復(fù)計(jì)算。

            ② 改進(jìn)計(jì)算子集合編號(hào)的算法:

            原程序的算法的時(shí)間復(fù)雜度是O(4^n),在n較大時(shí),相當(dāng)慢。

            ③ 對(duì)最后一個(gè)集合是否含有24的判斷:

            原程序要遍歷該集合所有的元素,效率比較差,可以考慮,在將兩個(gè)集合合并到該集合時(shí),只對(duì)取出的兩個(gè)元素的計(jì)算結(jié)果是否為24進(jìn)行判斷,這樣不僅省去最后的遍歷,而且不用將結(jié)果插入到最后的那個(gè)集合中,省去了大量操作。

             

            采用①和③兩種改進(jìn)方法后,程序運(yùn)行時(shí)間由原來(lái)的58秒縮短到了14秒,但這還不能讓人滿(mǎn)意。對(duì)2,3,5,6,85個(gè)數(shù),如果用書(shū)上的第一種方法,可以只調(diào)用4次函數(shù)就可以得到結(jié)果:2+3+5+6+8=24,但用集合的方法來(lái)處理,卻要對(duì)所有的集合進(jìn)行子集合合并后才能給出結(jié)果,這造成了效率極差,可以這樣改進(jìn)該算法:

            初始有n個(gè)集合:每一次任意取出2個(gè)集合,合并后,放回去,再取出任意2個(gè)集合,重復(fù)前面的操作,直到只剩下一個(gè)集合為止。

            例如:初始有5個(gè)數(shù),把這5個(gè)數(shù)分別放到5個(gè)集合,并分別編號(hào)為:124816。任意取出2個(gè)集合,假設(shè)為14,將14合并,得到編號(hào)為5(=1+4)的集合,剩下的集合為:52168,再取出2個(gè),假設(shè)為58,合并后,得到13216,再取2個(gè),假設(shè)為1316,合并后得到292,當(dāng)剩下2個(gè)集合時(shí),可以直接對(duì)這兩個(gè)集合間的的計(jì)算結(jié)果是否為24進(jìn)行判斷,直接得出結(jié)果,省去不必要的合并(合并后再判斷是否有元素近似等于24,程序運(yùn)行時(shí)間8s多,而直接對(duì)計(jì)算結(jié)果判斷,程序只要運(yùn)行1s多)。

            優(yōu)化后的程序,只要運(yùn)行1s多。但其效率還是不如書(shū)上的第一種方法的改進(jìn)版,仔細(xì)想想,n越大,集合的元素也就越多,兩個(gè)集合之間的合并,就越耗時(shí)間。而且采用集合保存中間結(jié)果,表面上減少了重復(fù)狀態(tài),會(huì)提高效率,但實(shí)際上,由于采用了集合,就多了很多不必要的計(jì)算,(比如,對(duì)2+3+5+6+8=24,最少只要4次計(jì)算就能得出結(jié)果,采用集合合并后,則要計(jì)算幾百次(約為6^4)),再加上實(shí)現(xiàn)集合所采用的數(shù)據(jù)結(jié)構(gòu)的開(kāi)銷(xiāo),效率高不了。

            24_set_1



            24_set_2.cpp


            24_set_3.cpp
            posted on 2010-08-15 23:35 flyinghearts 閱讀(973) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 算法編程之美C++
            亚洲国产精品无码成人片久久| 99久久久精品| 久久婷婷五月综合色奶水99啪| 深夜久久AAAAA级毛片免费看| 亚洲欧美成人久久综合中文网 | 久久久精品2019免费观看| 久久午夜无码鲁丝片秋霞| 无码国内精品久久人妻蜜桃| 久久久一本精品99久久精品88| 97r久久精品国产99国产精| 国产女人aaa级久久久级| 亚洲第一极品精品无码久久| 日本久久久久久久久久| 久久精品人成免费| 久久人人爽人人爽人人av东京热| 精品人妻伦九区久久AAA片69| 无码伊人66久久大杳蕉网站谷歌| 久久亚洲精品中文字幕三区| 香蕉久久av一区二区三区| 久久综合亚洲色HEZYO社区 | 少妇人妻综合久久中文字幕| 丁香久久婷婷国产午夜视频| 99re久久精品国产首页2020| 久久精品黄AA片一区二区三区| 久久伊人五月丁香狠狠色| 亚洲精品tv久久久久| 天堂无码久久综合东京热| 亚洲精品国产第一综合99久久 | 欧美午夜A∨大片久久 | 久久国产精品久久精品国产| 久久亚洲私人国产精品| 国产Av激情久久无码天堂| 精品精品国产自在久久高清| 国内精品久久久久久久久| 久久亚洲视频| 麻豆AV一区二区三区久久| 国产精品一区二区久久| 久久精品亚洲欧美日韩久久| 超级97碰碰碰碰久久久久最新| 97热久久免费频精品99| 久久伊人精品青青草原日本|