• <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 小鼠標 閱讀(1558) 評論(0)  編輯 收藏 引用 所屬分類: DP
            <2012年4月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            隨筆分類(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

            閱讀排行榜

            蜜臀久久99精品久久久久久| 国产A三级久久精品| 91精品国产色综久久| 91久久九九无码成人网站| 中文字幕久久亚洲一区| 久久精品国产亚洲AV无码麻豆| 久久成人影院精品777| 久久精品国产亚洲5555| 久久精品无码专区免费东京热| 久久99国产精品久久| 老男人久久青草av高清| 亚洲一本综合久久| 国产aⅴ激情无码久久| 久久精品一区二区影院 | 久久精品成人影院| 久久久久人妻一区二区三区vr| 久久久久久亚洲精品无码| AAA级久久久精品无码片| 国产精品99久久久精品无码| 久久97久久97精品免视看秋霞 | 91精品国产91久久综合| 伊人久久亚洲综合影院| 国产精品一区二区久久精品无码 | 要久久爱在线免费观看| 久久99精品国产99久久| 久久精品中文騷妇女内射| 中文字幕久久精品| 欧美成人免费观看久久| 欧美亚洲日本久久精品| 久久久无码精品亚洲日韩软件| 国产精品丝袜久久久久久不卡| 国产成人久久激情91| 久久99精品国产麻豆| 久久99精品久久只有精品| 国产精品99久久免费观看| 欧美牲交A欧牲交aⅴ久久| 日产精品99久久久久久| 国产精品无码久久综合| 狠狠色丁香久久综合五月| 久久精品国产精品亚洲精品| 国产精品久久久久久久久|