• <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>
            隨筆 - 51, 文章 - 1, 評論 - 41, 引用 - 0
            數據加載中……

            計算24點

                  計算24點有不同版本,這里規定:運用加減乘除計算四個整數使它的結果為24。當然這個算法經過適當的修改適合所有的二元運算符,也能計算超過四個整數。
                  
            計算24點的算法較簡單,就是窮舉法。由于一般計算表達式含有括號,這使得窮舉無從下手。所以本文使用另一種表達式——后綴表達式。 
                  后綴表達式就是數字放前運算符放后的表達式。如:a+b表示為a b+,(a+b)*c-d表示為a b + c * d -。用這樣表達式可以去掉括號,這對本文的算法很關鍵。
                  任何一個計算24點的算式都可以化成7位的后綴表達式
            假設給定的四個整數:a b c d。給定的運算符號集{+,-,*,/}。首先從符號集中取出三個運算符,然后加上a b c d。這七個單位的每一個排列都可以當成一個后綴表達式:或者是不合法的,或者是合法的。窮舉并計算這樣的排列,就可找出答案。
                  上面的方法是先取定7個單位,然后判斷這7個單位組成的表達式是否合法。換一種思路,先取定一個合法的表達式,即確定數字和符號的位置,然后確定7個單位,對應數字和符號的位置。
                  這兩種枚舉方法都可行,第二種會快一些,它把判斷后綴表達式合法性放在最外層循環,從而省去了不少的判斷。
                  注:這個里用的枚舉集合的方法參見另一篇文章《從集合中枚舉子集》
                  具體實現見代碼
                  編譯方式:
                  g++ Calc24.cpp SetIter.cpp   得到第一種方法。
                  g++ Calc24.cpp SetIter.cpp -DCALC24_ADV   得到第二種方法。

            posted on 2007-09-21 22:02 lemene 閱讀(772) 評論(2)  編輯 收藏 引用

            評論

            # re: 計算24點  回復  更多評論   

            您好!我覺得您的這個關于24點計算的想法很好!我想問個問題,就是說我要第二種方法,事先算出有五種后綴表達式的格式是正確的,之后我應該怎樣列舉出這些表達式呢?我覺得不停的迭代循環套的層太多了。請問您有什么好方法嗎
            2012-05-30 03:55 | jjx

            # re: 計算24點[未登錄]  回復  更多評論   

            @jjx
            這里只嵌套三層循環:
            第一層確定表達式的樣式,次數為C(3,7).
            第二層確定操作符,次數為P(3,5).
            第三層確定數字,如果數字沒有相同的,則次數為P(4,4).
            2012-06-10 22:22 | lemene
            欧美一区二区三区久久综| 国产美女亚洲精品久久久综合| 亚洲午夜无码久久久久| 久久久久四虎国产精品| 久久99精品国产麻豆婷婷| 色综合久久久久综合体桃花网| 亚洲精品高清久久| 亚洲国产成人久久精品影视| 国内精品久久久久影院薰衣草| 久久精品中文字幕一区| 国产99久久精品一区二区| 精品久久久久久无码中文野结衣| 日韩中文久久| 久久国产香蕉视频| 久久99久久99精品免视看动漫| 成人午夜精品无码区久久| 99精品久久久久久久婷婷| 久久久亚洲裙底偷窥综合| 久久精品国产一区二区电影| 久久久久成人精品无码| 久久99精品久久久久子伦| 婷婷综合久久中文字幕蜜桃三电影| avtt天堂网久久精品| 久久精品亚洲精品国产欧美| 亚洲国产精品久久久久婷婷软件 | 久久精品国产乱子伦| 蜜桃麻豆www久久| 国内精品人妻无码久久久影院 | 18岁日韩内射颜射午夜久久成人| 国产精品欧美亚洲韩国日本久久| 久久久女人与动物群交毛片| 久久综合九色综合网站| 久久国产亚洲高清观看| 国产激情久久久久久熟女老人| 热99RE久久精品这里都是精品免费 | 一本久久综合亚洲鲁鲁五月天| 人妻丰满?V无码久久不卡| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久er99热精品一区二区| 色偷偷888欧美精品久久久| 欧美一级久久久久久久大|