

下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
4/4動態(tài)規(guī)劃算法每天一道算法題(四)(動態(tài)規(guī)劃算法)01背包問題Java實現(xiàn)
動態(tài)規(guī)劃
動態(tài)規(guī)劃在wiki上的定義:
dynamicprogrammingisamethodforsolvingacomplexproblembybreakingitdownintoacollectionofsimplersubproblems,solvingeachofthosesubproblemsjustonce,andstoringtheirsolutions-ideally,usingamemory-baseddatastructure.Thenexttimethesamesubproblemoccurs,insteadofrecomputingitssolution,onesimplylooksupthepreviouslycomputedsolution。
昨天接觸到了動態(tài)規(guī)劃的概念,研究了昨天一晚上以及今天一上午,總算對這個問題有些收獲。
動態(tài)規(guī)劃背后的基本思想非常簡單。大致上,若要解一個給定問題,我們需要解其不同部分(即子問題),再合并子問題的解以得出原問題的解。
從空集合開始,每增加一個元素就求它的最優(yōu)解,直到所有元素加進(jìn)來,就得到了總的最優(yōu)解。
01背包問題
01背包問題即的01即每件物品最多放1件,否則不放入。
讓我真正了解動態(tài)規(guī)劃概念的是mu399的博客
問題:有編號分別為a,b,c,d,e的五件物品,它們的重量分別是
2,2,6,5,4,它們的價值分別是6,3,5,4,6,現(xiàn)在給你個承重為10的背包,如何讓背包里裝入的物品具有最大的價值總和?
重新定義問題:
有承重分別為1-10的背包10個
編號分別為a,b,c,d,e的物品各一個
3.從e物品開始依次放入1-10個背包,分別得到最大的價值總和
4.把d物品放入依次放入存在e物品的1-10個背包,如果價值更高,替換掉e()
5.c,b,a同理。。。
1.01背包的狀態(tài)轉(zhuǎn)換方程f[i,j]=Max{f[i-1,j-Wi]+Pi(j=Wi),f[i-1,j]}
f[i,j]:在前i件物品中選擇若干件放在承重為j的背包中,可以取得的最大價值。
Pi表示第i件物品的價值。
決策:為了背包中物品總價值最大化,第i件物品應(yīng)該放入背包中嗎?
2.以a8(行為a,列為的8的單元格)舉例
f[i,j]=a8=15
f[i-1,j]=b8=9
f[i-1,j-Wi]表示我有一個承重為6的背包(等于當(dāng)前背包承重減去物品a的重量),當(dāng)只有物品b,c,d,e四件可選時,這個背包能裝入的最大價值
f[i-1,j-Wi]+Pi=b(8-2)+6=b6+6=15背包的java代碼實現(xiàn)
publicclassgetPgAnswer{
publicvoidtestPackage(){
Package[]pg={newPackage("e",4,6),
newPackage("d",5,4),
newPackage("c",6,5),
newPackage("b",2,3),
newPackage("a",2,6)
--第一個參數(shù)表示從pg[0]開始依次放入的物品,--第二個參數(shù)代表背包的承重,放棄第0列數(shù)組
int[][]state=newint[pg.length][11];
intnewValue=0;
*01背包的狀態(tài)轉(zhuǎn)換方程
*f[i,j]=Max{
*f[i-1,j-Wi]+Pi(j=Wi),
*f[i-1,j]}
for(inti=0;ipg.length;i++){
--背包的承重量
for(intj=1;jstate[i].length;j++){
if(i==0){
if(pg[i].getWeight()=j){
state[i][j]=pg[i].getValue();
state[i][j]=state[i-1][j];
if(jpg[i].getWeight()){
continue;
newValue=state[i-1][j-pg[i].getWeight()]
+pg[i].getValue();
-*if(newValue=state[i-1][j]){
state[i][j]=newValue;
state[i][j]=state[i-1][j];
state[i][j]=Math.max(newValue,state[i-1][j]);
for(inti=0;istate.length;i++){
System.out.println(Arrays.toString(state[state.length-1-i]));
classPackage{
privateStringname;
privateintweight;
privateintvalue;
publicPackage(Stringname,intweight,intvalue){
http://./doc/9c0c87a60e22590102020740be1e650e52eacf20.html=name;
this.weight=weight;
this.value=value;
publicStringgetName(){
returnname;
publicintgetWeight(){
returnweight;
publicintgetValue(){
returnvalue;
背包的Python實現(xiàn)
問題:有編號分別為a,b,c,d,e的五件物品,它們的重量分別是2,2,6,5,4,它們的價值分別是6,3,5,4,6,
現(xiàn)在給你個承重為10的背包,如何讓背包里裝入的物品具有最大的價值總和?
思路:dynamicprogramming
即把整個問題分解成一系列子問題,所有子問題只計算一次并存起來,下一次相同問題出現(xiàn),直接從數(shù)據(jù)結(jié)構(gòu)中取出結(jié)果,而不是再次計算K(i,j)=max(K(i-1,j),K(i-1,j-Wi)+Pi)
其中j=Wi
f[i,j]:在前i件物品中選擇若干件放在承重為j的背包中,可以取得的最大價值。
Pi表示第i件物品的價值。
決策:為了背包中物品總價值最大化,第i件物品應(yīng)該放入背包中嗎defpackage(n,c,weight,values):
構(gòu)建背包問題二維表
:paramn:物品數(shù)量
:paramc:背包重量容積
:paramweight:物品重量列表
:paramvalues:物品價值列表
:return:
#初始化二維列表
res=[[-1forjinrange(c+1)]foriinrange(n+1)]
res[0]=[0foriinrange(1,c+1)]
#完善背包
foriinrange(1,n+1):
forjinrange(1,c+1):
res[1][j]=values[1]ifj=weights[1]else0
res[i][j]=res[i-1][j]
ifweights[i]jandres[i-1][j-weights[i]]+values[i]res[i][j]:
res[i][j]=res[i-1][j-weights[i]]+values[i]
#@Note:如果沒有上面的res[0]=[0foriinrange(1,c+1)]需要增加下面的判定
#elifweights[i]==jandvalues[i]res[i][j]:
#res[i][j]=values[i]
returnres
if__name__=='__main__':
#物品數(shù)量
#背包重量容積
#物品重量列表weights[0]無效和blog有區(qū)別博客是倒著放入商品
weights=[-1,2,2,6,5,4]
#物品價值列表values[0]無效
values=[-1,6,3,5,4,6]
res=package(n,c,weights,values)
如果枚舉的和總量大于等于選擇物品,則需要判斷是否選擇當(dāng)前物品*-
d[i][j]=min{d[i+1][j],d[i][j-1]}+1;(每次狀態(tài)轉(zhuǎn)移,區(qū)間長度增加1)
描述階段的變量稱為階段變量k。階段的劃分,一般是根據(jù)時間和空間的自然特征來進(jìn)行的,但要便于問題轉(zhuǎn)化為多階段決策。
最后一個元素相同:求X[1…m-1]和Y[1…n-1]兩個子序列的最長公共子序列。
voidTrace(inti,intcapacity)
從表中可以看出一些規(guī)律,除了第一行以外,每個格
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024-2025公司項目部管理人員安全培訓(xùn)考試試題(新)
- 2025企業(yè)安全培訓(xùn)考試試題考題
- 2024-2025工廠職工安全培訓(xùn)考試試題【能力提升】
- 2025合作伙伴關(guān)系確立合同書范本
- 2025電子產(chǎn)品贈送的合同范本
- 2025年大型無菌包裝機合作協(xié)議書
- 2025健康管理中心連鎖加盟合同書
- 2025標(biāo)準(zhǔn)辦公室租賃合同
- 2025年兼職翻譯服務(wù)合同范本
- 2025年兼職多職未簽訂合同男子失業(yè)又面臨法律訴訟管理資料糾紛
- 2025年審計審查重點試題及答案
- 2025年證券從業(yè)資格證考試真題試題及答案
- 城市管理文明執(zhí)法規(guī)范(試行)
- 廣東省2024-2025學(xué)年佛山市普通高中教學(xué)質(zhì)量檢測物理試卷及答案(二)高三試卷(佛山二模)
- 【9數(shù)一?!?025年安徽合肥市第四十五中學(xué)九年級中考一模數(shù)學(xué)試卷(含答案)
- 2025年中石油政工師理論考試題庫(含答案)
- 2025年二建-水利-簡答200問
- 安全專項施工方案內(nèi)容
- 2025天津市安全員《B證》考試題庫及答案
- 幼兒園趣味迷宮課件
- 數(shù)據(jù)中心運維服務(wù)投標(biāo)方案(技術(shù)標(biāo))
評論
0/150
提交評論