91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

動態規劃之什么是多重背包

發布時間:2021-10-19 11:00:58 來源:億速云 閱讀:97 作者:iii 欄目:web開發

本篇內容主要講解“動態規劃之什么是多重背包”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“動態規劃之什么是多重背包”吧!

多重背包

有N種物品和一個容量為V 的背包。第i種物品最多有Mi件可用,每件耗費的空間是Ci ,價值是Wi 。求解將哪些物品裝入背包可使這些物品的耗費的空間  總和不超過背包容量,且價值總和最大。

多重背包和01背包是非常像的, 為什么和01背包像呢?

每件物品最多有Mi件可用,把Mi件攤開,其實就是一個01背包問題了。

例如:

背包最大重量為10。

物品為:

 重量價值數量
物品01152
物品13203
物品24302

問背包能背的物品最大價值是多少?

和如下情況有區別么?

 重量價值數量
物品01151
物品01151
物品13201
物品13201
物品13201
物品24301
物品24301

毫無區別,這就轉成了一個01背包問題了,且每個物品只用一次。

這種方式來實現多重背包的代碼如下:

void test_multi_pack() {     vector<int> weight = {1, 3, 4};     vector<int> value = {15, 20, 30};     vector<int> nums = {2, 3, 2};     int bagWeight = 10;     for (int i = 0; i < nums.size(); i++) {         while (nums[i] > 1) { // nums[i]保留到1,把其他物品都展開             weight.push_back(weight[i]);             value.push_back(value[i]);             nums[i]--;         }     }      vector<int> dp(bagWeight + 1, 0);     for(int i = 0; i < weight.size(); i++) { // 遍歷物品         for(int j = bagWeight; j >= weight[i]; j--) { // 遍歷背包容量             dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);         }         for (int j = 0; j <= bagWeight; j++) {             cout << dp[j] << " ";         }         cout << endl;     }     cout << dp[bagWeight] << endl;  } int main() {     test_multi_pack(); }
  • 時間復雜度:O(m * n * k) m:物品種類個數,n背包容量,k單類物品數量

也有另一種實現方式,就是把每種商品遍歷的個數放在01背包里面在遍歷一遍。

代碼如下:(詳看注釋)

void test_multi_pack() {     vector<int> weight = {1, 3, 4};     vector<int> value = {15, 20, 30};     vector<int> nums = {2, 3, 2};     int bagWeight = 10;     vector<int> dp(bagWeight + 1, 0);       for(int i = 0; i < weight.size(); i++) { // 遍歷物品         for(int j = bagWeight; j >= weight[i]; j--) { // 遍歷背包容量             // 以上為01背包,然后加一個遍歷個數             for (int k = 1; k <= nums[i] && (j - k * weight[i]) >= 0; k++) { // 遍歷個數                 dp[j] = max(dp[j], dp[j - k * weight[i]] + k * value[i]);             }         }         // 打印一下dp數組         for (int j = 0; j <= bagWeight; j++) {             cout << dp[j] << " ";         }         cout << endl;     }     cout << dp[bagWeight] << endl;  } int main() {     test_multi_pack(); }
  • 時間復雜度:O(m * n * k) m:物品種類個數,n背包容量,k單類物品數量

從代碼里可以看出是01背包里面在加一個for循環遍歷一個每種商品的數量。和01背包還是如出一轍的。

當然還有那種二進制優化的方法,其實就是把每種物品的數量,打包成一個個獨立的包。

到此,相信大家對“動態規劃之什么是多重背包”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

柳林县| 武冈市| 凯里市| 尼勒克县| 平陆县| 武穴市| 宾川县| 同德县| 罗平县| 陆河县| 临武县| 洪泽县| 方山县| 易门县| 德阳市| 揭东县| 周宁县| 长岛县| 白玉县| 阳曲县| 扎赉特旗| 贵州省| 吉木乃县| 宝鸡市| 湾仔区| 民和| 资溪县| 内江市| 庆阳市| 左贡县| 武胜县| 安新县| 南投市| 雷波县| 临朐县| 大余县| 黑河市| 蒲城县| 上饶市| 甘泉县| 梅河口市|