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

            閱讀排行榜

            91精品国产综合久久精品| 国产免费久久精品99re丫y| 性欧美丰满熟妇XXXX性久久久| 青青草原精品99久久精品66| 99久久99久久久精品齐齐| 国内精品久久久久国产盗摄| 久久精品青青草原伊人| 久久91综合国产91久久精品| 色综合久久中文字幕综合网| 午夜精品久久久久久久久| 激情久久久久久久久久| 精品久久亚洲中文无码| 久久久久国色AV免费看图片| 久久久久久亚洲Av无码精品专口 | 国产∨亚洲V天堂无码久久久| 久久亚洲高清观看| 久久香综合精品久久伊人| 久久久精品国产Sm最大网站| av无码久久久久不卡免费网站| 亚洲欧洲精品成人久久曰影片| 国产精品久久久99| 国产精品岛国久久久久| 乱亲女H秽乱长久久久| 中文字幕精品久久| 欧美久久亚洲精品| 久久www免费人成看国产片| 蜜桃麻豆www久久| 99久久99久久久精品齐齐| 欧美丰满熟妇BBB久久久| 性做久久久久久久| 亚洲国产精品无码久久久秋霞2| 久久久精品国产免大香伊| 久久午夜福利电影| 久久久国产精品| 性高朝久久久久久久久久| 亚洲国产成人久久一区WWW| 久久精品这里只有精99品| 精品久久久久久无码人妻蜜桃| 情人伊人久久综合亚洲| 办公室久久精品| 婷婷国产天堂久久综合五月|