版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、背包問題 背包問題背包問題(Knapsack problem)是一種組合優(yōu)化的 NP 完全問題。問題可以描 述為:給定一組物品,每種物品都有自己的重量和價格,在限定的總重量內, 我們如何選擇,才能使得物品的總價格最高。問題的名稱來源于如何選擇最合 適的物品放置于給定背包中。相似問題經常出現在商業(yè)、組合數學,計算復雜 性理論、密碼學和應用數學等領域中。也可以將背包問題描述為決定性問題, 即在總重量不超過 W 的前提下,總價值是否能達到 V
2、?它是在 1978 年由 Merkel 和 Hellman 提出的 一、定義:背包問題屬于組合優(yōu)化問題,一般的最優(yōu)化問題由目標函數和約束條件兩 部部分組成:我們有 n 種物品,物品 i 的重量為 wi,價格為 pi。我們假定所有物品的重 量和價格都是非負的。背包所能承受的最大重量為 W。如果限定每種物品只能選擇 0 個或 1 個,則問題稱為 0-1 背包問題 背包問題??梢?用公式表示為:1maxni iip x? ?1. . ,ni
3、iiS T w x W?? ? ? ? 0,1 i x ?如果限定物品 i 最多只能選擇 bi 個,則問題稱為有界背包問題 有界背包問題??梢杂霉?式表示為:1maxni iip x? ?1. . ,ni iiS T w x W?? ? ? ? 0,1, , i i x b ? ???如果不限定每種物品的數量,則問題稱為無界背包問題 無界背包問題。 各類復雜的背包問題總可以變換為簡單的 0-1 背包問題進行求解。二、基本模型的建立方法
4、1、0-1 背包問題的數學模型(最基礎的背包問題)分類:0-1 背包問題簡單分為一維背包和二維背包問題。 特點:每種物品僅有一件,可以選擇放或不放。1.1 一維背包問題問題:一個旅行者準備進行徒步旅行,為此他必須決定攜帶若干物 品。設有 件物品可供他選擇,編號為 第 件物品重量為 千克, n 1,2,...,n i i w價值為 元,他能攜帶的最大重量為 千克。他應該裝入哪幾件物品價值 i p w最大。解:引入變量 ,且設 i x1,
5、( 1,2, , )0,ii x i ni? ? ? ? ?A A A 表示將第種物品裝入包中表示不將第種物品裝入包于是此問題的數學模型為:1maxni iif p x?? ?//c(i,j)=max{c(i-1,j), c(i-1,j-w[i])+vl(i)}for (i=1;ic[i-1][j]) {c[i][j]=vl[i]+c[i-1][j-w[i]];//選擇第 i 物品} elsec[i][j]=c[i-1][j];//不選
6、擇第 i 個物品} elsec[i][j]=c[i-1][j];//剩余容量不夠}//endfor}//endfor cout0;i--){if (c[i][temp_wei]==c[i-1][temp_wei])//最后一個肯定是最大價值的{x[i]=0;}else{x[i]=1;temp_wei-=w[i];}} cout<<“應裝入的物品有:“;for (i=0;i<=n;i++){if (x[i]){cout&
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論