• <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>
            題意描述:
            有六種不同價值的珠寶若干,問你能否把這些珠寶分成價值相等的兩份。當然,每個珠寶是不能切割的。
            非常明顯這一題是01背包問題,由于珠寶數量巨大,為了提高程序效率,我們要對同種價值的珠寶進行二進制拆分,這樣能夠迅速減少珠寶的數量(具體說來珠寶數量會變成O(logN)的數量級,N是原來珠寶的個數),二進制拆分后與原來是等效的,想想二進制數就明白了。
            01背包的狀態轉移方程為:
            當v<Ci時f[i,v]=f[i-1,v];(1)
            當v>=Ci時f[i,v]=Max(f[i-1,v],f[i-1,v-Ci]+Wi);(2)//當第i件物品能夠放下時,我們可以選擇放,或不放,取決于總價值的大小。
            其中v為當前背包的中容量,Ci表示第i件物品的體積,Wi表示第i件物品的價值,f[i,v]表示容量為v的背包在考慮前i件物品后的最大價值。
            上面的狀態轉移方程實現起來要開一個大小為I*V的二維數組(I為物品總個數,V為背包的總體積),可是有時候I和V可能很大,我們就需要很大的空間,甚至有可能超出范圍,其實在只考慮最終價值不關心到底選了那幾件物品時,上面轉移方程的空間是可以壓縮的。我們看到當考慮物品i時,我們用到的狀態只與第i-1件物品有關,因此空間壓縮的狀態轉移方程為:
            當v<Ci時f[v]=f[v];(3)
            當v>=Ci時f[v]=Max(f[v],f[v-Ci]+Wi);(4)
            利用(4)的時候求解順序很重要,要按v從大到小求,這樣才能保證前面的狀態不被覆蓋。
            這里說一下二進制拆分
            假設原來某一種類的珠寶數量為N,我們可以把N拆成1,2,4,8,……,2^(k-1),N-2^k+1。這些拆分成的數字能夠表示1~N之間的任何一個數。
            這樣,我們就把物品數減小為logN(以2為底,向上取整)。
            以下是本題代碼:

            posted on 2012-08-14 16:32 小鼠標 閱讀(1550) 評論(0)  編輯 收藏 引用 所屬分類: DP
            <2012年5月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            • 1.?re: 線段樹
            • 是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
              加油,祝你好運啦!
            • --小鼠標
            • 2.?re: 線段樹
            • 對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
            • --傷心的筆
            • 3.?re: poj1273--網絡流
            • 過來看看你。
            • --achiberx
            • 4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
            • 膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
            • --Hang
            • 5.?re: 快速排序、線性時間選擇
            • 博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
            • --lsxqw2004

            閱讀排行榜

            久久婷婷五月综合成人D啪| 午夜天堂精品久久久久| 久久偷看各类wc女厕嘘嘘| 无码国内精品久久人妻| 精品久久一区二区三区| 久久久精品视频免费观看| 久久这里只精品99re66| 欧美一区二区三区久久综| 精品久久久久久亚洲| 亚洲性久久久影院| 久久se精品一区二区| 怡红院日本一道日本久久| 香蕉aa三级久久毛片| 人妻精品久久久久中文字幕一冢本| 久久99国产精品99久久| 狠狠色婷婷久久综合频道日韩| 69国产成人综合久久精品| 性欧美大战久久久久久久| 国产亚洲婷婷香蕉久久精品| 人妻中文久久久久| 久久国产精品一区二区| 久久国语露脸国产精品电影| 国产成人精品久久一区二区三区av| 久久夜色精品国产噜噜噜亚洲AV | 久久精品日日躁夜夜躁欧美| 高清免费久久午夜精品| 亚洲人成精品久久久久| 久久夜色精品国产噜噜亚洲a| 日本免费一区二区久久人人澡| 久久久久女人精品毛片| 久久亚洲中文字幕精品一区| 精品久久久久久无码人妻热| 老司机国内精品久久久久| 久久永久免费人妻精品下载| 99久久国产宗和精品1上映| 一级a性色生活片久久无少妇一级婬片免费放| 久久综合给久久狠狠97色| 日本久久久久亚洲中字幕| 久久亚洲精品无码AV红樱桃| 人妻丰满AV无码久久不卡| 久久精品欧美日韩精品|