版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第七章 動(dòng)態(tài)規(guī)劃主要內(nèi)容介紹7.1 一般方法和基本要素7.2 最大字段和7.3 每對(duì)結(jié)點(diǎn)間的最短路徑7.4 矩陣連乘問題7.5 最長(zhǎng)公共子序列問題7.6最優(yōu)二叉搜索樹主要內(nèi)容介紹7.7 0-1背包問題7.8流水作業(yè)調(diào)度引言動(dòng)態(tài)規(guī)劃算法與分治法類似,其基本思想也是將待求解問題分解成若干個(gè)子問題。經(jīng)分解得到的子問題往往不是互相獨(dú)立的。不同子問題的數(shù)目常常只有多項(xiàng)式量級(jí)。在用分治法求解時(shí),有些子問題被重復(fù)計(jì)算了許多次。如果能夠保存已解決的子問題的答案,而在需要時(shí)再找出已求得的答案,就可以避免大量重復(fù)計(jì)算,從而得到多項(xiàng)式時(shí)間算法。nT(n/2)T(n/2)T(n/2)T(n/2)T(n)=nT(n)=
2、n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)n=n/2T(n/4)T(n/4)T(n/4)T(n/4)n/2n/2T(n/4)T(n/4)n/2T(n/4)T(n/4)T(n/4)T(n/4)T(n/4)T(n)Those who cannot remember the past are doomed to repeat it.George Santayana, The life of Reason, Book I: Int
3、roduction and Reason in Common Sense (1905)第七章 動(dòng)態(tài)規(guī)劃7.1 一般方法1. 多階段決策問題 多階段決策過程:?jiǎn)栴}的活動(dòng)過程分為若干相互聯(lián)系的階段,任一階段i以后的行為僅依賴于i階段的過程狀態(tài),而與i階段之前的過程如何達(dá)到這種狀態(tài)的方式無關(guān)。在每一個(gè)階段都要做出決策,這決策過程稱為多階段決策過程(multistep decision process) 。 最優(yōu)化問題:?jiǎn)栴}的每一階段可能有多種可供選擇的決策,必須從中選擇一種決策。各階段的決策構(gòu)成一個(gè)決策序列。決策序列不同,所導(dǎo)致的問題的結(jié)果可能不同。 多階段決策的最優(yōu)化問題就是:求能夠獲得問題最優(yōu)解
4、的決策序列最優(yōu)決策序列。2. 多階段決策過程的求解策略1)枚舉法 窮舉可能的決策序列,從中選取可以獲得最優(yōu)解的決策序列2)動(dòng)態(tài)規(guī)劃 20世紀(jì)50年代初美國(guó)數(shù)學(xué)家R.E.Bellman等人在研究多階段決策過程的優(yōu)化問題時(shí),提出了著名的最優(yōu)化原理(principle of optimality),把多階段過程轉(zhuǎn)化為一系列單階段問題,創(chuàng)立了解決這類過程優(yōu)化問題的新方法動(dòng)態(tài)規(guī)劃。 動(dòng)態(tài)規(guī)劃(dynamic programming)是運(yùn)籌學(xué)的一個(gè)分支,是求解決策過程(decision process)最優(yōu)化的數(shù)學(xué)方法。 應(yīng)用領(lǐng)域:動(dòng)態(tài)規(guī)劃問世以來,在經(jīng)濟(jì)管理、生產(chǎn)調(diào)度、工程技術(shù)和最優(yōu)控制等方面得到了廣泛
5、的應(yīng)用。例如最短路線、庫存管理、資源分配、設(shè)備更新、排序、裝載等問題,用動(dòng)態(tài)規(guī)劃方法比用其它方法求解更為方便。3. 最優(yōu)性原理(Principle of Optimality) 過程的最優(yōu)決策序列具有如下性質(zhì):無論過程的初始狀態(tài)和初始決策是什么,其余的決策都必須相對(duì)于初始決策所產(chǎn)生的狀態(tài)構(gòu)成一個(gè)最優(yōu)決策序列。 利用動(dòng)態(tài)規(guī)劃求解問題的前提 1) 證明問題滿足最優(yōu)性原理 如果對(duì)所求解問題證明滿足最優(yōu)性原理,則說明用動(dòng)態(tài)規(guī)劃方法有可能解決該問題 2) 獲得問題狀態(tài)的遞推關(guān)系式 獲得各階段間的遞推關(guān)系式是解決問題的關(guān)鍵。Divide-and-conquer技術(shù)的問題子問題是相互獨(dú)立的如果子問題不是相互
6、獨(dú)立的,分治方法將重復(fù)計(jì)算公共子問題,效率很低優(yōu)化問題給定一組約束條件和一個(gè)代價(jià)函數(shù),在解空間中搜索具有最小或最大代價(jià)的優(yōu)化解很多優(yōu)化問題可分為多個(gè)子問題,子問題相互關(guān)聯(lián),子問題的解被重復(fù)使用Why? Dynamic Programming特點(diǎn)把原始問題劃分成一系列子問題求解每個(gè)子問題僅一次,并將其結(jié)果保存在一個(gè)表中,以后用到時(shí)直接存取,不重復(fù)計(jì)算,節(jié)省計(jì)算時(shí)間自底向上地計(jì)算適用范圍一類優(yōu)化問題:可分為多個(gè)相關(guān)子問題,子問題的解被重復(fù)使用What? 使用Dynamic Programming的條件Optimal substructure(優(yōu)化子結(jié)構(gòu))當(dāng)一個(gè)問題的優(yōu)化解包含了子問題的優(yōu)化解時(shí),我
7、們說這個(gè)問題具有優(yōu)化子結(jié)構(gòu)??s小子問題集合,只需那些優(yōu)化問題中包含的子問題,減低實(shí)現(xiàn)復(fù)雜性優(yōu)化子結(jié)構(gòu)使得我們能自下而上地完成求解過程Subteties(重疊子問題)在問題的求解過程中,很多子問題的解將被多次使用How? Dynamic Programming算法的設(shè)計(jì)步驟分析優(yōu)化解的結(jié)構(gòu)遞歸地定義最優(yōu)解的代價(jià)自底向上地計(jì)算優(yōu)化解的代價(jià)保存之, 并獲取構(gòu)造最優(yōu)解的信息根據(jù)構(gòu)造最優(yōu)解的信息構(gòu)造優(yōu)化解 多段圖問題多段圖G=(V,E)是一個(gè)有向圖,且具有特性: 結(jié)點(diǎn):結(jié)點(diǎn)集V被分成k2個(gè)不相交的集合Vi,1ik, 其中V1和Vk分別只有一個(gè)結(jié)點(diǎn):s(源結(jié)點(diǎn))和t(匯點(diǎn))。 段: 每一集合Vi定義圖中的
8、一段共k段。 邊: 所有的邊(u,v)均具有如下性質(zhì): 若E,則 若uVi,則uVi1,即該邊將是從某段i指向i+1段, 1ik1。 成本:每條邊(u,v)均附有成本c(u,v)。 s到t的路徑:是一條從第1段的源點(diǎn)s出發(fā),依次經(jīng)過第2段的某結(jié)點(diǎn)v2,i,經(jīng)第3段的某結(jié)點(diǎn)v3,j、最后在第k段的匯點(diǎn)t結(jié)束的路徑。 該路徑的成本是這條路徑上邊的成本和。 多段圖問題:求由s到t的最小成本路徑。7.1.2 多段圖問題12345678910111297324327111181456356425V1V2V3V4V55段圖7.1.2 多段圖問題1. 問題的描述 在多段圖中求從s到t的一條最小成本的路徑,可
9、以看 作是在k-2個(gè)段作出某種決策的結(jié)果。 第i次決策決定Vi+1中的哪個(gè)結(jié)點(diǎn)在這條路徑上,這里 1ik-2; 最優(yōu)性原理對(duì)多段圖問題成立 多段圖問題的多階段決策過程:生成從s到t的最小成本路徑是在k-2個(gè)階段(除s和t外)進(jìn)行某種決策的過程:從s開始,第i次決策決定Vi+1(1ik-2)中的哪個(gè)結(jié)點(diǎn)在從s到t的最短路徑上。 最優(yōu)性原理對(duì)多段圖問題成立 假設(shè)s,v2,v3,vk-1,t是一條由s到t的最短路徑。 初始狀態(tài):s 初始決策:(s,v2), v2V2 初始決策產(chǎn)生的狀態(tài):v2 則,其余的決策:v3,.,vk-1相對(duì)于v2將構(gòu)成一個(gè)最優(yōu)決策序列最優(yōu)性原理成立。 反證:若不然,設(shè)v2,q
10、3,qk-1,t是一條由v2到t的更短的路徑,則s, v2,q3,qk-1,t將是比s,v2,v3,vk-1,t更短的從s到t的路徑。與假設(shè)矛盾。 故,最優(yōu)性原理成立即,是v2 v3,.,vk-1t構(gòu)成從v2至t的最短路徑4. 最優(yōu)決策序列的表示 設(shè) S0:?jiǎn)栴}的初始狀態(tài) n次決策:?jiǎn)栴}需要做n次決策 xi:i階段的決策值,1in。 設(shè)X1=r1,1,r1,2,r1,p1是x1可選決策值的集合,S1,j1是在選擇決策值r1,j1之后所產(chǎn)生的狀態(tài)“初始決策”所產(chǎn)生的狀態(tài)。 設(shè)1,j1是相應(yīng)于狀態(tài)S1,j1的最優(yōu)決策序列。則,相應(yīng)于S0的最優(yōu)決策序列就是r1,j11,j1|1j1p1中最優(yōu)的序列,
11、記為 就一個(gè)特定的r1,j1而言s0r1,1r1,2.r1,p1sn1,j11,11,21p1 若已經(jīng)做了k-1次決策,1k-1n,設(shè)x1,x2,xk-1的最優(yōu)決策值是r1,r2,rk-1,所產(chǎn)生的狀態(tài)依次為S1,S2,Sk-1。 設(shè)Xk=rk,1,rk,2,rk,pk是xk可能的決策值的集合,Sk,jk是在選擇決策值rk,jk之后所產(chǎn)生的狀態(tài), 1jkpk。 k,jk是相應(yīng)于狀態(tài)Sk,jk的最優(yōu)決策序列。則,相應(yīng)于Sk-1的最優(yōu)決策序列是 相應(yīng)于S0的最優(yōu)決策序列為r1,rk-1,rk, k就一個(gè)特定的rk,jk而言s0 s1 s2. sk-1rk,1rk,2.rk,pksnk,jkk,1k
12、,2kpk2. 向前處理策略求解 設(shè) P(i,j)是一條從Vi中的結(jié)點(diǎn)j到匯點(diǎn)t的最小成本路徑, COST(i,j)是這條路徑的成本。 1) 向前遞推式 2) 遞推過程 第k-1段 c(j,t) E COST(k-1,j) = l1l2.lpi+1tjViVi+112345678910111297324227111181456356425V1V2V3V4V55段圖各遞推結(jié)果第4段 COST(4,9) = c(9,12) = 4 COST(4,10) = c(10,12) = 2 COST(4,11) = c(11,12) = 5第3段 COST(3,6) = min6+COST(4,9),5+
13、COST(4,10) = 7 COST(3,7) = min4+COST(4,9),3+COST(4,10) = 5 COST(3,8) = min5+COST(4,10),6+COST(4,11) = 7第2段 COST(2,2) = min4+COST(3,6) , 2+COST(3,7), 1+COST(3,8) = 7 COST(2,3) = 9 COST(2,4) = 18 COST(2,5) = 15第1段 COST(1,1) = min9+COST(2,2),7+COST(2,3), 3+COST(2,4),2+COST(2,5) = 16S到t的最小成本路徑的成本 16 最小成
14、本路徑的求取 記 D(i,j)每一COST(i,j)的決策 即,使c(j,l)+COST(i+1,l)取得最小值的l值。 例:D(3,6) = 10, D(3,7)= 10 D(3,8) = 10 D(2,2) = 7, D(2,3) = 6,D(2,4) = 8,D(2,5) = 8 D(1,1) = 2 根據(jù)D(1,1)的決策值向后遞推求取最小成本路徑: v2=D(1,1)=2 v3 = D(2,D(1,1) = 7 v4 = D(3,D(2,D(1,1) = D(3,7) = 10 故由s到t的最小成本路徑是:1271012 3) 算法描述 結(jié)點(diǎn)的編號(hào)規(guī)則 源點(diǎn)s編號(hào)為1,然后依次對(duì)V2
15、、V3Vk-1中的結(jié)點(diǎn)編號(hào),匯點(diǎn)t編號(hào)為n。 目的:使對(duì)COST和D的計(jì)算僅按n-1,n-2,1的次序計(jì)算即可,無需考慮標(biāo)示結(jié)點(diǎn)所在段的第一個(gè)下標(biāo)。 算法描述算法7.1 多段圖的向前處理算法 procedure FGRAPH(E,k,n,P) /輸入是按段的順序給結(jié)點(diǎn)編號(hào)的,有n個(gè)結(jié)點(diǎn)的k段圖。E是邊 集,c(i,j)是邊的成本。P(1:k)帶出最小成本路徑/ real COST(n); integer D(n-1),P(k),r,j,k,n COST(n)0 for jn-1 to 1 by -1 do /計(jì)算COST(j)/ 設(shè)r是具有性質(zhì):E且使c(j,r)+COST(r)取最小值的結(jié)點(diǎn)
16、 COST(j)c(j,r) + COST(r) D(j) r /記錄決策值/ repeat P(1)1; P(k)n for j2 to k-1 do /找路徑上的第j個(gè)結(jié)點(diǎn)/ P(j) D(P(j-1) /回溯求出該路徑/ repeat end FGRAPH算法的時(shí)間復(fù)雜度 若G采用鄰接表表示,總計(jì)算時(shí)間為:3. 向后處理策略求解 設(shè) BP(i,j)是一條從源點(diǎn)s到Vi中的結(jié)點(diǎn)j的最小成本路徑, BCOST(i,j)是這條路徑的成本。 1) 向后遞推式 2) 遞推過程 第2段 c(1,j) E COST(2,j) = 123456789101112973242271111814563564
17、25V1V2V3V4V55段圖各遞推結(jié)果第2段 BCOST(2,2) = 9 BCOST(2,3) = 7 BCOST(2,4) = 3 BCOST(2,5) = 2第3段 BCOST(3,6) = minBCOST(2,2)+4,BCOST(2,3)+2 = 9 BCOST(3,7) = minBCOST(2,2)+2,BCOST(2,3)+7, BCOST(2,5)+11 = 11 BCOST(3,8) = minBCOST(2,4)+11, BCOST(2,5)+8 = 10第4段 BCOST(4,9) = minBCOST(3,6)+6,BCOST(3,7)+4 = 15 BCOST(
18、4,10) = minBCOST(3,6)+5,BCOST(3,7)+3, BCOST(3,8)+5 = 14 BCOST(4,11) = minBCOST(3,8)+6 = 16第5段 BCOST(5,12) = minBCOST(4,9)+4,BCOST(4,10)+2, BCOST(4,11)+5 = 16S到t的最小成本路徑的成本 16 最小成本路徑的求取 記 BD(i,j)每一COST(i,j)的決策 即,使COST(i-1,l)+c(l,j)取得最小值的l值。 例:BD(3,6) = 3, BD(3,7)= 2 ,BD(3,8) = 5 BD(4,9) = 6, BD(4,10)
19、= 7, BD(4,11) = 8 BD(5,12) = 10 根據(jù)D(5,12)的決策值向前遞推求取最小成本路徑: v4 = BD(5,12)=10 v3 = BD(4,BD(5,12) = 7 v2 = BD(3,BD(4,BD(5,12) = BD(3,7) = 2 故由s到t的最小成本路徑是:1271012 算法7.2 多段圖的向后處理算法 procedure BGRAPH(E,k,n,P) /輸入是按段的順序給結(jié)點(diǎn)編號(hào)的,有n個(gè)結(jié)點(diǎn)的k段圖。E是邊 集,c(i,j)是邊的成本。P(1:k)帶出最小成本路徑/ real BCOST(n); integer BD(n-1),P(k),r,
20、j,k,n BCOST(1)0 for j2 to n do /計(jì)算BCOST(j)/ 設(shè)r是具有E且使BCOST(r)+ c(r,j)取最小值性質(zhì)的結(jié)點(diǎn) BCOST(j) BCOST(r)+ c(r,j) BD(j) r /記錄決策值/ repeat P(1)1; P(k)n for jk-1 to 2 by -1 do /找路徑上的第j個(gè)結(jié)點(diǎn)/ P(j) D(P(j+1) /回溯求出該路徑/ repeat end BGRAPH4. 多段圖問題的應(yīng)用實(shí)例資源的分配問題 將n個(gè)資源分配給r個(gè)項(xiàng)目的問題:如果把j個(gè)資源,0jn,分配給項(xiàng)目i,可以獲得N(i,j)的凈利。 問題:如何將這n個(gè)資源分
21、配給r個(gè)項(xiàng)目才能使各項(xiàng)目獲得的凈利之和達(dá)到最大。 轉(zhuǎn)換成一個(gè)多段圖問題求解。 用r1段圖描述該問題: 段: 1到r之間的每個(gè)段i表示項(xiàng)目i。 結(jié)點(diǎn): i=1時(shí),只有一個(gè)結(jié)點(diǎn)源點(diǎn)s =V(1,0) 當(dāng)2ir時(shí),每段有n+1個(gè)結(jié)點(diǎn),每個(gè)結(jié)點(diǎn)具有形式 V(i,j):表示到項(xiàng)目i之前為止,共把j個(gè)資源分配給了 前i-1個(gè)項(xiàng)目,j=0,1,n。 匯點(diǎn)t=V(r+1,n) 邊的一般形式:,jl,1ir 成本: 當(dāng)jl且1ir時(shí),邊賦予成本 N(i,l-j),表示給項(xiàng)目i分配l-j個(gè)資源所可能獲得的凈利。 當(dāng)jn且i=r時(shí),此時(shí)的邊為:,該邊賦 予成本:指向匯點(diǎn)的邊注,并不是分給的資源越多,得到的凈利就越大
22、實(shí)例:將4個(gè)資源分配給3個(gè)項(xiàng)目。構(gòu)成一個(gè)4段圖。 問題的解:資源的最優(yōu)分配方案由一條s到t的最大成本路徑給出改變邊成本的符號(hào),從而將問題轉(zhuǎn)換成為求取最小成本路徑問題。7.2 最大子段和問題描述:給定由n個(gè)整數(shù)(包含負(fù)整數(shù))組成的序列a1,a2,.,an,求該序列子段和的最大值。當(dāng)所有整數(shù)均為負(fù)值時(shí)定義其最大子段和為0。依此定義,所求的最優(yōu)值為: 例如,當(dāng)(a1,a2, a3, a4, a5,a6)=(-2,11,-4,13,-5,-2)時(shí),最大子段和為: 1. 一個(gè)簡(jiǎn)單算法一個(gè)簡(jiǎn)單算法:int MaxSum(int n, a, &besti, &bestj)int sum=0;for(i=1;
23、i=n;i+)for(j=1;j=n;j+)int thissum=0;for(k=i;ksum)sum=thissum;besti=i;Bestj=j;return sum;算法有3重循環(huán),復(fù)雜性為O(n3)。由于有:算法可作如下改進(jìn):int MaxSum(int n, a, &besti, &bestj)int sum=0;for(i=1;i=n;i+)int thissum=0;for(j=1;jsum)sum=thissum;besti=i;bestj=j;改進(jìn)后的算法復(fù)雜性為O(n2) 。2. 分治方法求解從問題的解的結(jié)構(gòu)可以看出,它適合于用分治策略求解:如果將所給的序列a1:n分為
24、長(zhǎng)度相等的兩段a1:n/1和an/2+1:n,分別求出這兩段的最大子段和,則a1:n的最大子段和有三種情形:a1:n的最大子段和與a1:n/2的最大子段和相同;a1:n的最大子段和與an/2+1:n的最大子段和相同;a1:n的最大子段和為下面的形式。A、B這兩種情形可遞歸求得。對(duì)于情形C,容易看出,an/2與an/2+1在最優(yōu)子序列中。因此,我們可以在a1:n/2和an/2+1:n中分別計(jì)算出如下的s1和s2。則s1+s2即為出現(xiàn)情形C使得最優(yōu)值。 從而設(shè)計(jì)出下面所示的分治算法。int MaxSubSum(int a, int left, int right) int sum=0; if (l
25、eft=right)sum=aleft0?aleft:0; elseint center=(left+right)/2; int leftsum=MaxSubSum(a,left,center); int rightsum=MaxSubSum(a,center+1,right); int s1=0;lefts=0; for (int i=center;i=left;i-) lefts+=ai; if (leftss1) s1=lefts; int s2=0;rights=0; for (int i=center+1;is2) s2=rights; sum=s1+s2; if (sumlefts
26、um) sum=leftsum; if (sum0時(shí)bj=bj-1+aj,否則bj=aj。由此可得計(jì)算bj的動(dòng)態(tài)規(guī)劃遞歸式bj=maxbj-1+aj,aj,1jn。據(jù)此,可設(shè)計(jì)出求最大子段和的動(dòng)態(tài)規(guī)劃算法如下:int MaxSum(int n, int a)int sum=0; b=0;for (i=1;i0) b+=ai; else b=ai;if (bsum) sum=b;return sum;顯然該算法的計(jì)算時(shí)間為O(n)。4. 算法的推廣最大矩陣和問題,略最大m子段和問題,略7.3 每對(duì)結(jié)點(diǎn)之間的最短路徑1. 問題描述 設(shè)G=(V,E)是一個(gè)有n個(gè)結(jié)點(diǎn)的有向圖,C是G的成本鄰接矩陣,C
27、中元素有: 0 ,i j c(i,j)= 邊的成本,ij且E(G) ,ij且 其中,1i,jn 每對(duì)結(jié)點(diǎn)之間的最短路徑問題:求滿足下述條件的矩陣A,A中的任一元素A(i,j)代表結(jié)點(diǎn)i到結(jié)點(diǎn)j的最短路徑長(zhǎng)度。分析: 利用單源最短路徑算法求解 計(jì)算n個(gè)結(jié)點(diǎn)的單源最短路徑。 時(shí)間復(fù)雜度:(n3)利用動(dòng)態(tài)規(guī)劃策略求解 將求解G中每對(duì)結(jié)點(diǎn)之間的最短路徑問題轉(zhuǎn)化成一個(gè)多階段決策過程。 決策什么? 最優(yōu)性原理對(duì)于該問題是否成立?2. 動(dòng)態(tài)規(guī)劃求解策略1)最優(yōu)性原理對(duì)于每對(duì)結(jié)點(diǎn)之間的最短路徑問題成立 對(duì)G的一條由i到j(luò)的最短路徑(假設(shè)該路徑中不包含環(huán)),設(shè)k是該路徑上的一個(gè)中間結(jié)點(diǎn): i,.,k,j 由i到
28、k的最短路徑 k是中間結(jié)點(diǎn) 由k到i的最短路徑 則,由i到k和k到j(luò)的兩條子路徑將分別是由i到k和由k到j(luò)的最短路徑。(反證,否則i,.,k,j也將不是由i到j(luò)的最短路徑) 故,最優(yōu)性原理對(duì)于該問題成立。2)多階段決策過程 所有n個(gè)結(jié)點(diǎn)從1到n依次編號(hào)。 設(shè)k是由i到j(luò)的最短路徑上編號(hào)最高的中間結(jié)點(diǎn): i,.,k,j k是編號(hào)最高的中間結(jié)點(diǎn) 則由i到k的子路徑上將不會(huì)有比編號(hào)k-1更大的結(jié)點(diǎn);同理,由k到j(luò)的子路徑上也將不會(huì)有比編號(hào)k-1更大的結(jié)點(diǎn)。 構(gòu)造多階段決策過程:對(duì)由i到j(luò)的最短路徑,首先決策哪一個(gè)結(jié)點(diǎn)是該路徑上具有最大編號(hào)的中間結(jié)點(diǎn)k,然后再去求取由i到k和由k到j(luò)的最短路徑其中應(yīng)不
29、包含比k-1還大的中間結(jié)點(diǎn)。3)遞推關(guān)系式 記Ak(i,j)表示從i到j(luò)并且不經(jīng)過比k還大的結(jié)點(diǎn)的最短路徑長(zhǎng)度。則, A(i,j) = An(i,j) 即,由i到j(luò)的最短路徑不通過編號(hào)比n還大的結(jié)點(diǎn)。 注:該路徑可以經(jīng)過結(jié)點(diǎn)n,也可以不經(jīng)過結(jié)點(diǎn)n。 若該路徑經(jīng)過結(jié)點(diǎn)n,則 An(i,j) An-1(i,n) + An-1(n,j) 若該路徑不經(jīng)過結(jié)點(diǎn)n,則 An(i,j) An-1(i,j) 故可得, An(i,j) = minAn-1(i,j) ,An-1(i,n) + An-1(n,j) 不經(jīng)過n結(jié)點(diǎn) 經(jīng)過n結(jié)點(diǎn) 對(duì)任意的k, k1,有, Ak(i,j) = minAk-1(i,j) ,A
30、k-1(i,k) + Ak-1(k,j) 不經(jīng)過結(jié)點(diǎn)k 剛好經(jīng)過結(jié)點(diǎn)k 初值: A0(i,j)= C(i,j),1in,1jn遞推計(jì)算: A1(i,j), A2(i,j), An(i,j)= A (i,j)3. 算法描述算法7.3 每對(duì)結(jié)點(diǎn)之間的最短路徑長(zhǎng)度 procedure ALL-PATHS(COST,A,n) /COST(n,n)是n結(jié)點(diǎn)圖的成本鄰接矩陣;A(i,j)是結(jié)點(diǎn)vi到vj的最短路 徑的成本;COST(i,i)=0,1in/ integer I,j,k,n; real COST(n,n),A(n,n) for i1 to n do for j1 to n do A(i,j)
31、COST(i,j) /用COST(i,j)對(duì)A0賦初值/ repeat repeat for k1 to n do for i1 to n do for j1 to n do A (i,j) minA (i,j) ,A (i,k) + A (k,j) repeat repeat repeat end ALL-PATHS算法的設(shè)計(jì)說明1) Ak(i,k) = Ak-1(i,k) Ak(k,j) = Ak-1(k,j) (i,j)(i,k)(k,j)(k,k)ik且kj,則有Ak(i,j) minAk-1(i,j), Ak(i,k) + Ak-1(k,j) 在第i-1到第i次的迭代過程中,A的第k
32、行、第k列元素不變ki且jk,則有Ak(i,j) minAk-1(i,j), Ak-1(i,k) + Ak(k,j) (k,k)(k,j)(i,k)(i,j)(k,j)(k,k)(i,j)(i,k)ki且kj,則有Ak(i,j) minAk-1(i,j), Ak(i,k) + Ak(k,j) Ak(i,j) minAk-1(i,j), Ak(i,k) + Ak-1(k,j) Ak(i,j) minAk-1(i,j), Ak-1(i,k) + Ak(k,j) Ak(i,j) minAk-1(i,j), Ak(i,k) + Ak(k,j) Ak(i,j) minAk-1(i,j), Ak-1(i,
33、k) + Ak-1(k,j) 在算法的計(jì)算過程中取消了A的上標(biāo),并保證了每次計(jì)算 的 Ak(i,j)即為 minAk-1(i,j), Ak-1(i,k) + Ak-1(k,j) 2)如何求每對(duì)結(jié)點(diǎn)之間的路徑?例7.3 有向圖如圖所示A0123104112602330A11231041126023370A2123104626023370A3123104625023370642 113v1v2v3123104112602330求圖中所有結(jié)點(diǎn)間最短路徑的成本矩陣注: A(i,j) = 表明G中從i到j(luò)沒有有向路徑性能分析 計(jì)算時(shí)間 注:該時(shí)間與A的值無關(guān): for k1 to n do 迭代n次 f
34、or i1 to n do 迭代n次 for j1 to n do 迭代n次 A (i,j) minA (i,j) ,A (i,k) + A (k,j) repeat repeat repeat7.4 矩陣連乘問題給定n個(gè)矩陣A1,A2,.,An,其中Ai與Ai+1是可乘的,i=1,2,.,n-1??疾爝@n個(gè)矩陣的連乘積A1A2.An。由于矩陣乘法滿足結(jié)合律,所以計(jì)算矩陣的連乘可以有許多不同的計(jì)算次序。這種計(jì)算次序可以用加括號(hào)的方式來確定。若一個(gè)矩陣連乘積的計(jì)算次序完全確定,也就是說該連乘積已完全加括號(hào),則可以依此次序反復(fù)調(diào)用2個(gè)矩陣相乘的標(biāo)準(zhǔn)算法計(jì)算出矩陣連乘積。7.4 矩陣連乘問題完全加括
35、號(hào)的矩陣連乘積可遞歸地定義為:?jiǎn)蝹€(gè)矩陣是完全加括號(hào)的;矩陣連乘積A是完全加括號(hào)的,則A可表示為2個(gè)完全加括號(hào)的矩陣連乘積B和C的乘積并加括號(hào),即A=(BC)。7.4矩陣連乘問題設(shè)有四個(gè)矩陣A,B,C,D,它們的維數(shù)分別是:A=5010,B=1040,C=4030,D=305總共有五種完全加括號(hào)的方式:(A(BC)D) (A(B(CD) (AB)(CD) (AB)C)D) (A(BC)D)其數(shù)乘次數(shù)分別為:16000, 10500, 36000, 87500, 345007.4 .1 窮舉搜索法問題描述:給定n個(gè)矩陣A1,A2,An,其中Ai與Ai+1是可乘的,i=1,2,n-1。如何確定計(jì)算矩
36、陣連乘積的計(jì)算次序,使得依此次序計(jì)算矩陣連乘積需要的數(shù)乘次數(shù)最少。窮舉法:列舉出所有可能的計(jì)算次序,并計(jì)算出每一種計(jì)算次序相應(yīng)需要的數(shù)乘次數(shù),從中找出一種數(shù)乘次數(shù)最少的計(jì)算次序。 7.4.1 窮舉搜索法算法復(fù)雜度分析:對(duì)于n個(gè)矩陣的連乘積,設(shè)其不同的計(jì)算次序?yàn)镻(n)。由于每種加括號(hào)方式都可以分解為兩個(gè)子矩陣的加括號(hào)問題:(A1.Ak)(Ak+1An)可以得到關(guān)于P(n)的遞推式如下: P(n)是隨n的增長(zhǎng)成指數(shù)增長(zhǎng)的。動(dòng)態(tài)規(guī)劃法1.分析最優(yōu)解的結(jié)構(gòu)預(yù)處理:將矩陣連乘積A1A2.An簡(jiǎn)記為Ai:j,這里ij??疾煊?jì)算Ai:j的最優(yōu)計(jì)算次序。設(shè)這個(gè)計(jì)算次序在矩陣Ak和Ak+1之間將矩陣鏈斷開,i
37、kj,則其相應(yīng)完全加括號(hào)方式為(A1A2. Ak)(Ak+1 Ak+2. An )。計(jì)算量:Ai:k的計(jì)算量加上Ak+1:j的計(jì)算量,再加上Ai:k和Ak+1:j相乘的計(jì)算量。動(dòng)態(tài)規(guī)劃法1.分析最優(yōu)解的結(jié)構(gòu)分析最優(yōu)解的結(jié)構(gòu)特征:計(jì)算Ai:j的最優(yōu)次序所包含的計(jì)算矩陣子鏈 Ai:k和Ak+1:j的次序也是最優(yōu)的。矩陣連乘計(jì)算次序問題的最優(yōu)解包含著其子問題的最優(yōu)解。這種性質(zhì)稱為最優(yōu)子結(jié)構(gòu)性質(zhì)。問題的最優(yōu)子結(jié)構(gòu)性質(zhì)是該問題可用動(dòng)態(tài)規(guī)劃算法求解的顯著特征。2.建立遞歸關(guān)系設(shè)計(jì)算Ai:j,1ijn,所需要的最少數(shù)乘次數(shù)mi,j,則原問題的最優(yōu)值為m1,n。當(dāng)i=j時(shí),Ai:j=Ai,因此,mi,i=0,
38、i=1,2,n。當(dāng)ij時(shí),mi,j=mi,k+mk+1,j+pi-1pkpj,這里Ai的維數(shù)為pi-1pi??梢赃f歸地定義mi,j為: k的位置只有j-1種可能。3.計(jì)算最優(yōu)值對(duì)于1ijn不同的有序?qū)?i,j)對(duì)應(yīng)于不同的子問題。因此,不同子問題的個(gè)數(shù)最多只有在遞歸計(jì)算時(shí),許多子問題被重復(fù)計(jì)算多次。這也是該問題可用動(dòng)態(tài)規(guī)劃算法求解的又一顯著特征。用動(dòng)態(tài)規(guī)劃算法解此問題,可依據(jù)其遞歸式以自底向上的方式進(jìn)行計(jì)算。在計(jì)算過程中,保存已解決的子問題答案。每個(gè)子問題只計(jì)算一次,而在后面需要時(shí)只要簡(jiǎn)單查一下,從而避免大量的重復(fù)計(jì)算,最終得到多項(xiàng)式時(shí)間的算法。7.3.3矩陣連乘算法算法描述【程序73】矩陣連
39、乘算法class MatrixChainpublic: MatrixChain(int mSize,int *q); int MChain(); int LookupChain(); void Traceback(); private: void Traceback(int i,int j); int LookupChain(int i, int j); int *p,*m,*s,n; int MatrixChain:MChain() /求A0:n-1的最優(yōu)解值 for (int i=0;in;i+) mii=0; for (int r=2; r=n;r+) for (int i=0;i=n-
40、r;i+) int j=i+r-1; mij=mi+1j+pi*pi+1*pj+1; sij=i; for (int k=i+1;kj;k+) int t=mik +mk+1j+pi*pk+1*pj+1; if (tmij) mij=t;sij=k; return m0n-1;void MatrixChain:Traceback(int i,int j) if(i=j) coutAi;return; if (isij) cout(; Traceback(i,sij);if (isij)cout); if(sij+1j)cout(; Traceback(sij+1,j);if(sij+1j) c
41、out);void MatrixChain:Traceback() cout(; Traceback(0,n-1);cout); cout 0) return mij;if (i = j) return 0;int u = LookupChain(i,i) + LookupChain(i+1,j) + pi-1*pi*pj;sij = i;for (int k = i+1; k j; k+) int t = LookupChain(i,k) + LookupChain(k+1,j) + pi-1*pk*pj;if (t u) u = t; sij = k;mij = u;return u;算法
42、復(fù)雜性:T(n)=O(n3)關(guān)于動(dòng)態(tài)規(guī)劃算法和備忘錄方法的適用條件矩陣連乘積的最優(yōu)計(jì)算次序問題可用自頂向下的備忘錄方法或自底向上的動(dòng)態(tài)規(guī)劃算法在O(n3)計(jì)算時(shí)間內(nèi)求解。這兩個(gè)算法都利用了子問題重疊性質(zhì)。總共有(n2)個(gè)不同的子問題,對(duì)每個(gè)子問題兩種算法都只解一次并記錄答案。當(dāng)再次遇到該子問題時(shí),簡(jiǎn)單地取用已得到的答案,節(jié)省了計(jì)算量,提高了算法的效率。關(guān)于動(dòng)態(tài)規(guī)劃算法和備忘錄方法的適用條件適用條件:一般來說,當(dāng)一個(gè)問題的所有子問題都至少要解一次時(shí),用動(dòng)態(tài)規(guī)劃算法比用備忘錄方法好。此時(shí),動(dòng)態(tài)規(guī)劃算法沒有任何多余的計(jì)算,還可以利用其規(guī)則的表格存取方式來減少在動(dòng)態(tài)規(guī)劃算法中的計(jì)算時(shí)間和空間需求。當(dāng)子
43、問題空間中部分子問題可以不必求解時(shí),易用備忘錄方法則較為有利,因?yàn)閺钠淇刂平Y(jié)構(gòu)可以看出,該方法只解那些確實(shí)需要求解的子問題。7.5 Longest Common Susequence 問題的定義 最長(zhǎng)公共子序列 (LCS) 結(jié)構(gòu)分析 建立求解LCS長(zhǎng)度的遞歸方程 自底向上LCS長(zhǎng)度的計(jì)算 構(gòu)造優(yōu)化解定義:若給定序列X=x1,x2,xm,則另一序列Z=z1,z2,zk,是X的子序列是指存在一個(gè)嚴(yán)格遞增下標(biāo)序列i1,i2,ik使得對(duì)于所有j=1,2,k有:zj=xij。例如,序列Z=B,C,D,B是序列X=A,B,C,B,D,A,B的子序列,相應(yīng)的遞增下標(biāo)序列為2,3,5,7。給定2個(gè)序列X和Y,
44、當(dāng)另一序列Z既是X的子序列又是Y的子序列時(shí),稱Z是序列X和Y的公共子序列。給定2個(gè)序列X=x1,x2,xm和Y=y1,y2,yn,找出X和Y的最長(zhǎng)公共子序列。 最長(zhǎng)公共子序列(LCS)問題輸入:X = (x1,x2,.,xn),Y = (y1,y2,.ym)輸出:Z = X與Y的最長(zhǎng)公共子序列最長(zhǎng)公共子序列結(jié)構(gòu)分析第i前綴設(shè)X=(x1, x2, ., xn)是一個(gè)序列,X的第i前綴Xi是一個(gè)序列,定義為Xi=(x1, ., xi ) 例. X=(A, B, D, C, A), X1=(A), X2=(A, B), X3=(A, B, D)優(yōu)化子結(jié)構(gòu)定理1(優(yōu)化子結(jié)構(gòu))設(shè)X=(x1, ., xm
45、)、Y=(y1, ., yn)是兩個(gè)序列,Z=(z1, ., zk)是X與Y的LCS,我們有: 如果xm=yn, 則zk=xm=yn, Zk-1是Xm-1和Yn-1的LCS, 即,LCSXY = LCSXm-1Yn-1+ . 如果xmyn,且zkxm,則Z是Xm-1和Y的LCS,即LCSXY= LCSXm-1Y 如果xmyn,且zkyn,則Z是X與Yn-1的LCS,即LCSXY= LCSXYn-1最長(zhǎng)公共子序列的結(jié)構(gòu)設(shè)序列X=x1,x2,xm和Y=y1,y2,yn的最長(zhǎng)公共子序列為Z=z1,z2,zk ,則若xm=yn,則zk=xm=yn,且zk-1是xm-1和yn-1的最長(zhǎng)公共子序列。若xm
46、yn且zkxm,則Z是xm-1和Y的最長(zhǎng)公共子序列。若xmyn且zkyn,則Z是X和yn-1的最長(zhǎng)公共子序列。由此可見,2個(gè)序列的最長(zhǎng)公共子序列包含了這2個(gè)序列的前綴的最長(zhǎng)公共子序列。因此,最長(zhǎng)公共子序列問題具有最優(yōu)子結(jié)構(gòu)性質(zhì)。 證明: . X=, Y=,則 LCSXY = LCSXm-1Yn-1+ . 設(shè)zkxm,則可加xm=yn到Z,得到一個(gè)長(zhǎng)為k+1的X與Y的公共序列,與Z是X和Y的LCS矛盾。于是zk=xm=yn。 現(xiàn)在證明Zk-1是Xm-1與Yn-1的LCS。顯然Zk-1是Xm-1與Yn-1的公共序列。我們需要證明Zk-1是LCS。 設(shè)不然,則存在Xm-1與Yn-1的公共子序列W,W
47、的長(zhǎng)大于k-1。增加xm=yn到W,我們得到一個(gè)長(zhǎng)大于k的X與Y的公共序列,與Z是LCS矛盾。于是,Zk-1是Xm-1與Yn-1的LCS. X=, Y=,xmyn,zkxm,則 LCSXY= LCSXm-1Y 由于zkxm,Z是Xm-1與Y的公共子序列。我們來證Z是Xm-1與Y的LCS。設(shè)Xm-1與Y有一個(gè)公共子序列W,W的長(zhǎng)大于k, 則W也是X與Y 的公共子序列,與Z是LCS矛盾。 同可證。子問題的遞歸結(jié)構(gòu)由最長(zhǎng)公共子序列問題的最優(yōu)子結(jié)構(gòu)性質(zhì)建立子問題最優(yōu)值的遞歸關(guān)系。用cij記錄序列和的最長(zhǎng)公共子序列的長(zhǎng)度。其中, Xi=x1,x2,xi;Yj=y1,y2,yj。當(dāng)i=0或j=0時(shí),空序列
48、是Xi和Yj的最長(zhǎng)公共子序列。故此時(shí)Cij=0。其它情況下,由最優(yōu)子結(jié)構(gòu)性質(zhì)可建立遞歸關(guān)系如下: 計(jì)算最優(yōu)值由于在所考慮的子問題空間中,總共有(mn)個(gè)不同的子問題,因此,用動(dòng)態(tài)規(guī)劃算法自底向上地計(jì)算最優(yōu)值能提高算法的效率。 void LCSLength(int m,int n,char *x,char *y,int *c,int *b) int i,j;for (i = 1; i = m; i+) ci0 = 0;for (i = 1; i = n; i+) c0i = 0;for (i = 1; i = m; i+)for (j = 1; j =cij-1) cij=ci-1j; bij=
49、2;else cij=cij-1; bij=3; 構(gòu)造最長(zhǎng)公共子序列算法描述:void LCS(int i,int j,char *x,int *b)if (i =0 | j=0) return;if (bij= 1) LCS(i-1,j-1,x,b); coutT01(左子樹),T24(右子樹) T01=1 =T00(左子樹),T11(右子樹) T24=3 =T22(左子樹),T34(右子樹) T34=4 =T33(左子樹),T44(右子樹) 0123402,0,03,0,01,0,01,0,01,0,018,8,17,7,23,3,33,3,4212,19,19,12,25,8,3316,
50、25,211,19,2416,32,2W(j,j+i),C(j,j+i),R(j,j+i)ji樹的形態(tài)ifdoreadwhile3.計(jì)算時(shí)間 當(dāng)j-i=m時(shí),有n-m+1個(gè)C(i,j)要計(jì)算 C(i,j)的計(jì)算:(m) 每個(gè)C(i,j)要求找出m個(gè)量中的最小值。 則,n-m+1個(gè)C(i,j)的計(jì)算時(shí)間: (nm-m2) 對(duì)所有可能的m,總計(jì)算時(shí)間為: 一種改進(jìn)措施(克努特):最優(yōu)的kR(i,j-1),R(i+1,j) Donald E. Knuth Optimum binary search trees Acta Information 1971 4.算法描述 procedure OBST(P
51、,Q,n) /給定n個(gè)標(biāo)識(shí)符a1a2an。已知成功檢索的概率P(i),不成功檢索概率Q(i), 0in。算法對(duì)于標(biāo)識(shí)符ai+1,aj計(jì)算最優(yōu)二分檢索樹Tij的成本C(i,j)、根R(i,j)、權(quán)W(i,j) / real P(1:n),Q(1:n),C(0:n,0:n),W(0:n,0:n);integer R(0:n,0:n) for i0 to n-1 do (W(i,i), R(i,i), C(i,i)(Q(i),0,0) /置初值/ (W(i,i+1), R(i,i+1), C(i,i+1)(Q(i)+Q(i+1)+P(i+1),i+1, Q(i)+Q(i+1)+P(i+1) repe
52、at /含有一個(gè)結(jié)點(diǎn)的最優(yōu)樹/ (W(n,n), R(n,n), C(n,n)(Q(n),0,0) for m2 to n do for i0 to n-m do ji+m W(i,j) W(i,j-1)+P(j)+Q(j) k區(qū)間R(i,j-1), R(i+1,j)中使C(i,l-1)+C(l,j)取最小值的l值 /Knuth結(jié)論/ C(i,j) W(i,j)+C(i,k-1)+C(k,j) R(i,j)k repeat repeat end OBSTOBST算法的計(jì)算時(shí)間:(n2)對(duì)滿足動(dòng)態(tài)規(guī)劃最優(yōu)性原理的多階段決策問題有,當(dāng)問題的一決策序列為最優(yōu)時(shí),其中任何一段子序列相對(duì)于該子序列所對(duì)應(yīng)
53、的子問題構(gòu)成該子問題的最優(yōu)解。但對(duì)有些多階段決策問題,盡管存在問題的最優(yōu)決策序列,但最優(yōu)性原理并不一定成立(從而也就不能用動(dòng)態(tài)規(guī)劃策略求解)。試舉例說明。1. 問題描述 1) KNAP(1,j,X) 目標(biāo)函數(shù): 約束條件: 0/1背包問題:KNAP(1,n,M) 最優(yōu)性原理對(duì)于0/1背包問題成立 求解策略:向前遞推、向后遞推 7.7 0/1背包問題2) 向后遞推關(guān)系式 記fj(X)是KNAP(1,j,X)的最優(yōu)解,則fn(M)有 fn(M) = maxfn-1(M),fn-1(M-wn)+pn 對(duì)于任意的fi(X),i0,有 fi(X) = maxfi-1(X),fi-1(X-wi)+pi 遞
54、推過程: 初始值 0 X0 f0= X0 求出fi在所有可能的X取值情況下的值。 fn(M)=KNAP(1,n,M)例7.11 背包問題 n=3,(w1,w2,w3)=(2,3,4),(p1,p2,p3)=(1,2,5),M=6 遞推計(jì)算過程 X0 f0(X)= 0 X0 X0 f1(X)= max0,+1=0 0X2 max0,0+1 = 1 X2 X0 max0,+3=0 0X2 f2(X)= max1,+3=1 2X3 max1,0+2=2 3X5 max1,1+2 = 3 X5 f3(M)= max3,1+5 = 6 M=6盡管X0,但還不足以裝下w1解向量的推導(dǎo) f3(M)=6 x3
55、=1 P=6-p3=1 KNAP(1,3,6)=6 M=6-w3=2 X=(1,0,1) f2(M)=1 x2=0 f1(M)=1 x1=1 f1,f2,f3計(jì)算過程的圖解i:fi-1(x-wi) + pii=0:函數(shù)不存在1234567012i1:f0(x-w1) + p1x1234567012i2:f1(x-w2) + p23x1234567012f1(x)x1234567012f0(x)=0 x12345670123xf2(x)12345670678x1234589i3:f2(x-w3) + p312345670678x1234589f3(x)10注: fi-1(X-wi)+pi曲線的構(gòu)
56、造:將fi-1(X)的曲線在X軸上右移wi個(gè)單位,然后上移pi個(gè)單位而得到; fi(X)曲線的構(gòu)造:由fi-1(X) 和fi-1(X-wi)+pi的曲線按X相同時(shí)f取大值的規(guī)則歸并而成2. 序偶表示 記 fi的序偶集合為 Si = (Pj,Wj)|Wj是fi曲線中使得fi產(chǎn)生一次階躍的X值, 0jr 即Pj=fi(Wj),r是階躍點(diǎn)個(gè)數(shù) (P0,W0)=(0,0) 若共有r個(gè)階躍值,則分別對(duì)應(yīng)r個(gè)(Pj,Wj)序偶, 1jr 若WjWj+1,則PjPj+1,0jr 若WjXWj+1,fi(X)=fi(Wj) 若XWr,fi(X)=fi(Wr)fi是關(guān)于X的階躍函數(shù) Si的構(gòu)造 記 是fi-1(
57、X-wj)+pj的所有序偶的集合,則 其中,Si-1是fi-1的所有序偶的集合 Si的構(gòu)造:由Si-1和 按照支配規(guī)則合并而成。 支配規(guī)則:如果Si-1和 之一有序偶(Pj,Wj),另一有(Pk,Wk), 且有 WjWk , Pj Pk, 則序偶(Pj,Wj)將被舍棄。 (即取最大值規(guī)則)。 注: Si中的序偶是背包問題KNAP(1,i,X)在X各種 取值下子問題的最優(yōu)解例7.12 例7.11的序偶計(jì)算 S0=(0,0) =(1,2) S1=(0,0),(1,2) =(2,3),(3,5) S2=(0,0),(1,2), (2,3),(3,5) =(5,4),(6,6), (7,7),(8,9
58、) S3=(0,0),(1,2), (2,3),(5,4),(6,6), (7,7),(8,9) 注:序偶(3,5)被(5,4)“支配”而刪除KNAP(1,n,M)問題的解決策序列的求取 Sn是KNAP(1,n,X)在0XM各種取值下的最優(yōu)解 KNAP(1,n,M)的最優(yōu)解由Sn的最后一對(duì)有效序偶給出。xi的推導(dǎo) xn: 設(shè)Sn的最后一對(duì)有效序偶是(P1,W1),W1M,則 (P1,W1)或者是Sn1的最末一對(duì)序偶,或者是(Pj+pn,Wj+wn), 其中 (Pj,Wj) Sn1且Wj是Sn1中滿足Wj+wnM的最大值。 若(P1,W1) Sn1,則Xn0;否則, (P1pn,W1-wn) S
59、n1 ,Xn1 xn-1: 若xn=0,則判斷(P1,W1) Sn2?,以確定Xn-1的值 若xn=1,則依據(jù)(P1pn,W1-wn) Sn2?,以判斷Xn-1的值 xn-2,x1將依次推導(dǎo)得出 例7.13 (例7.12) S0=(0,0) S1=(0,0),(1,2) S2=(0,0),(1,2), (2,3),(3,5) S3=(0,0),(1,2), (2,3),(5,4),(6,6), (7,7),(8,9) M=6,f3(6)由S3中的序偶(6,6)給出。 1) (6,6) S2 x3=1 2) (6-p3,6-w3)=(1,2)S2且(1,2)S1 x2=0 3) (1,2) S0
60、 x1=1算法7.6 非形式的背包算法 procedure DKP(p,w,n,M) S0 (0,0) for i1 to n-1 do (P1,W1)|(P1-pi,W1-wi) Si-1 and W1M /生成 / Si MERGE-PURGE(Si-1, ) /將Si-1和 歸并為Si/ repeat (PX,WX) Sn-1的最末一個(gè)有效序偶 (PY,WY)(P1pn,W1+wn),其中,W1是Sn-1中使得WwnM的所有序偶中取最大值得W /沿Sn-1, S1回溯確定xn,xn-1,x1的取值/ if PXPY then xn0 /PX將是Sn的最末序偶/ else xn1 /PY將
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 關(guān)注三年級(jí)孩子的個(gè)性化發(fā)展:班主任工作計(jì)劃
- 【名師一號(hào)】2020-2021學(xué)年高中英語(人教版)必修一雙基限時(shí)練6
- 【先學(xué)后教新思路】2020高考物理一輪復(fù)習(xí)-教案5-電學(xué)設(shè)計(jì)性實(shí)驗(yàn)的處理
- 2025年八年級(jí)統(tǒng)編版語文寒假復(fù)習(xí) 專題03 文言文閱讀(考點(diǎn)剖析+對(duì)點(diǎn)訓(xùn)練)
- 2021高考化學(xué)考前沖刺40天練習(xí):專題3-氧化還原反應(yīng)1
- 江蘇省揚(yáng)州市江都區(qū)2024-2025學(xué)年九年級(jí)上學(xué)期1月期末歷史試題(含答案)
- 二年級(jí)蝸牛爬井詳細(xì)解題思路
- 八年級(jí)下英語單詞
- 2024-2025學(xué)年內(nèi)蒙古呼倫貝爾市扎蘭屯市九年級(jí)(上)期末英語試卷(含答案)
- 【創(chuàng)新設(shè)計(jì)】2021高考化學(xué)(江蘇專用)二輪專題提升練:第4講-物質(zhì)結(jié)構(gòu)和元素周期律(含新題及解析)
- 醫(yī)學(xué)課件-新生兒腹瀉護(hù)理查房教學(xué)課件
- 蘇教版中外戲劇名著選讀《玩偶之家》評(píng)課稿
- 運(yùn)用PDCA循環(huán)提高標(biāo)本送檢率品管圈QCC成果匯報(bào)
- 線性代數(shù)PPT(本科)全套完整教學(xué)課件
- 2023-2024學(xué)年云南省昆明市小學(xué)語文四年級(jí)期末深度自測(cè)題詳細(xì)參考答案解析
- 全《12個(gè)維度細(xì)化部門管理》市場(chǎng)部部門職責(zé)
- 2022年廣東省普通高中學(xué)業(yè)水平第一次合格性考試歷史真題卷
- 經(jīng)方在消化系統(tǒng)疾病中的運(yùn)用
- 高標(biāo)準(zhǔn)農(nóng)田施工組織設(shè)計(jì)(全)
- 格庫鐵路S標(biāo)項(xiàng)目部二工區(qū)混凝土拌和站管理辦法
- 《靈飛經(jīng)》原帖對(duì)照鋼筆字帖
評(píng)論
0/150
提交評(píng)論