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

            閱讀排行榜

            国产成人精品白浆久久69| 精品久久久久久无码人妻蜜桃| 久久精品国产只有精品2020| 午夜精品久久久久久影视riav| 婷婷综合久久中文字幕| 久久久久中文字幕| 中文字幕成人精品久久不卡| 久久综合中文字幕| 99久久亚洲综合精品网站| 91超碰碰碰碰久久久久久综合| 精品久久久久久| 久久综合久久综合久久| 久久久99精品成人片中文字幕| 国产精品成人99久久久久 | 成人综合伊人五月婷久久| 蜜臀av性久久久久蜜臀aⅴ麻豆| 亚洲av日韩精品久久久久久a| 久久精品人成免费| 久久综合久久久| 一级做a爰片久久毛片免费陪| 久久精品国产亚洲AV久| 久久久老熟女一区二区三区| 热久久国产精品| 婷婷久久五月天| 久久久久女人精品毛片| 久久99精品久久久久久噜噜 | 国产精品对白刺激久久久| 青青草国产成人久久91网| 久久久久国产| 婷婷久久香蕉五月综合加勒比| 女人香蕉久久**毛片精品| 无码任你躁久久久久久老妇| 欧美熟妇另类久久久久久不卡| 久久亚洲高清观看| 久久人人爽人人爽人人片AV高清| 99国产欧美精品久久久蜜芽 | 亚洲人成电影网站久久| 久久综合久久自在自线精品自| 国产精品欧美亚洲韩国日本久久| 97精品依人久久久大香线蕉97| 久久综合狠狠综合久久激情 |