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

            雁過無痕

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::

            《編程之美》讀書筆記22:    1.16  24點游戲(補充)

             

            給定n個數,能否只通過加減乘除計算得到24

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

            對數值都在113之間的n個數的所有組合進行判斷。在n等于4時,實現的程序約過1秒就給出了結果,而n等于5時,程序要運行58秒,效率實在差,可以通過這幾方面優化:

            ① 保存每個集合的子集合的編號:

            對給定的n,共有12^n – 1個集合,每個集合的子集合編號是固定的,但原程序每計算一個n個數的組合,都要對這些子集合編號計算一遍,可以保存每個集合的子集合編號,減少大量的重復計算。

            ② 改進計算子集合編號的算法:

            原程序的算法的時間復雜度是O(4^n),在n較大時,相當慢。

            ③ 對最后一個集合是否含有24的判斷:

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

             

            采用①和③兩種改進方法后,程序運行時間由原來的58秒縮短到了14秒,但這還不能讓人滿意。對2,3,5,6,85個數,如果用書上的第一種方法,可以只調用4次函數就可以得到結果:2+3+5+6+8=24,但用集合的方法來處理,卻要對所有的集合進行子集合合并后才能給出結果,這造成了效率極差,可以這樣改進該算法:

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

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

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

            24_set_1



            24_set_2.cpp


            24_set_3.cpp
            posted on 2010-08-15 23:35 flyinghearts 閱讀(965) 評論(0)  編輯 收藏 引用 所屬分類: 算法編程之美C++
            成人午夜精品无码区久久| 国产一区二区三区久久精品| 欧美国产精品久久高清| 伊人精品久久久久7777| 亚洲精品乱码久久久久66| 久久免费小视频| 日本精品久久久久久久久免费| 99久久免费国产精品特黄| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 色综合久久88色综合天天 | 久久国产欧美日韩精品免费| 久久ZYZ资源站无码中文动漫| 久久精品国产国产精品四凭| av色综合久久天堂av色综合在| 国产福利电影一区二区三区久久久久成人精品综合 | 日韩人妻无码精品久久久不卡| 久久精品国产亚洲AV蜜臀色欲| 久久国产精品无码一区二区三区| 久久国产美女免费观看精品| 99国产精品久久久久久久成人热| 久久久久综合国产欧美一区二区| 91精品国产高清久久久久久io| 久久久久久久波多野结衣高潮| 精品人妻伦九区久久AAA片69| 久久亚洲私人国产精品| 一本久久免费视频| 国产亚洲精久久久久久无码AV| 亚洲午夜久久久久久久久电影网| 日韩电影久久久被窝网| 国产日韩久久免费影院| 亚洲综合久久综合激情久久| 99热成人精品热久久669| 久久人人爽爽爽人久久久| 无码国内精品久久综合88| 亚洲а∨天堂久久精品9966| 久久人人超碰精品CAOPOREN | 精品伊人久久大线蕉色首页| 一本久久a久久精品综合香蕉 | 国产亚洲美女精品久久久久狼| 欧美丰满熟妇BBB久久久| 久久久精品国产sm调教网站|