算法設(shè)計與分析 課件 第七章 分支限界_第1頁
算法設(shè)計與分析 課件 第七章 分支限界_第2頁
算法設(shè)計與分析 課件 第七章 分支限界_第3頁
算法設(shè)計與分析 課件 第七章 分支限界_第4頁
算法設(shè)計與分析 課件 第七章 分支限界_第5頁
已閱讀5頁,還剩57頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

計算機算法設(shè)計與分析第7章分支限界法7.1.1廣度優(yōu)先搜索策略廣度優(yōu)先搜索(Breadth-FirstSearch,BFS)策略是一種常用的圖遍歷搜索算法,用于在圖或樹結(jié)構(gòu)中搜索特定的目標(biāo)?;舅枷胍环N分層的搜索過程,它從給定的起始頂點開始,以廣度優(yōu)先的方式一層一層搜索圖中的節(jié)點,直到找到目標(biāo)節(jié)點或遍歷完整個圖。為了實現(xiàn)逐層訪問,算法中使用了一個隊列,以記憶待訪問的結(jié)點,以便于向下一層擴(kuò)展結(jié)點。給定圖G=(V,E),創(chuàng)建一個隊列,用于存儲待訪問的結(jié)點;為避免重復(fù)訪問,需要創(chuàng)建一個輔助數(shù)組visited[],給被訪問過的結(jié)點加標(biāo)記。廣度優(yōu)先搜索策略基本步驟為:(1)初始化,將起始結(jié)點放入隊列中,并將其標(biāo)記為已訪問。(2)當(dāng)隊列不空,執(zhí)行以下步驟:①從隊列中取出一個結(jié)點。②檢查該結(jié)點是否是目標(biāo)結(jié)點。如果是,則搜索結(jié)束。③如果該結(jié)點不是目標(biāo)結(jié)點,則將其所有未被訪問過的鄰居結(jié)點放入隊列中,并標(biāo)記它們?yōu)橐言L問。(3)重復(fù)步驟(2),直到找到目標(biāo)結(jié)點搜索成功而結(jié)束,或者隊列為空且沒有找到目標(biāo)結(jié)點,搜索失敗而結(jié)束。7.1.1廣度優(yōu)先搜索策略BFS的偽代碼BFS(start,target)begin

創(chuàng)建隊列Q,并初始化隊列;Q.queueAppend(start)//起始出發(fā)點入隊,queueAppend入隊操作visited[start]

true//置已訪問標(biāo)記whilenotQ.isEmpty()do//isEmpty()判隊空操作node=Q.queueDel()//queueDel出隊操作

ifnode==targetthennode結(jié)點處理;returntrue;endifforneighborinnode.neighborsdo//枚舉node的所有相鄰結(jié)點ifvisited[neighbor]=falsethen//相鄰且沒有被訪問過的結(jié)點Q.queueAppend(neighbor)//入隊visited[neighbor]

true//置已訪問標(biāo)記 endif endfor

endwhilereturnfalseend效率分析鄰接矩陣存儲的圖進(jìn)行廣度優(yōu)先搜索算法,每個結(jié)點查找的鄰接頂點所需時間為O(|V|),則總時間復(fù)雜度為O(|V|2)??臻g復(fù)雜度為O(|V|2),另外我們需要使用一個隊列和一個輔助數(shù)組來存儲結(jié)點和訪問狀態(tài)。鄰接表存儲的圖進(jìn)行廣度優(yōu)先搜索算法的時間復(fù)雜度為O(|V|+|E|),其中|V|是結(jié)點的數(shù)量,|E|是邊的數(shù)量。這是因為我們需要遍歷所有的結(jié)點和邊。計算機算法設(shè)計與分析第7章分支限界法7.2.1分支限界方式分支限界法根據(jù)從活結(jié)點表中選擇下一個擴(kuò)展結(jié)點的方式,可分為隊列式分支限界和優(yōu)先隊列式分支限界。(1)隊列式分支限界法隊列式(FIFO)式分支限界法的基本思想:(1)首先將初始狀態(tài)節(jié)點放入活結(jié)點隊列中。(2)若隊列非空,則重復(fù)下列步驟:①出隊,將出隊結(jié)點作為當(dāng)前擴(kuò)展結(jié)點。②判斷當(dāng)前擴(kuò)展結(jié)點是否為目標(biāo)結(jié)點,若是目標(biāo)結(jié)點,則搜索到一個可行解而結(jié)束。③對當(dāng)前擴(kuò)展結(jié)點進(jìn)行擴(kuò)展。在擴(kuò)展節(jié)點時,一次性產(chǎn)生它的所有子結(jié)點,并利用剪枝函數(shù)檢測,把滿足約束和限界條件的的子結(jié)點依次加入活結(jié)點隊列。(3)重復(fù)(2),直到隊列為空,則搜索失敗結(jié)束。(2)優(yōu)先隊列式分支限界法將活結(jié)點表組成一個優(yōu)先隊列,按照優(yōu)先隊列中指定的結(jié)點優(yōu)先級,選取優(yōu)先級最高的結(jié)點作為當(dāng)前擴(kuò)展結(jié)點,以優(yōu)先隊列儲存活結(jié)點。結(jié)點的優(yōu)先級常用一個與該結(jié)點相關(guān)的限界函數(shù)值來表示。也稱為最小耗費優(yōu)先分支限界法(LC)該策略與隊列式分支限界法的主要區(qū)別是:優(yōu)先隊列式分支限界法的活結(jié)點表組成一個優(yōu)先隊列,每個活結(jié)點入隊時會計算其優(yōu)先級,優(yōu)先級最高的活結(jié)點位于隊首位置。(2)優(yōu)先隊列式分支限界法優(yōu)先隊列通常采用堆數(shù)據(jù)結(jié)構(gòu)來組織,通過維護(hù)堆屬性,可以保證優(yōu)先隊列的入隊操作時按結(jié)點元素優(yōu)先級重新排序,也即隊列中優(yōu)先級最高的結(jié)點元素始終位于隊列首部位置。每次出隊的隊首結(jié)點總是當(dāng)前隊列中具有優(yōu)先級最高(最有利)的結(jié)點成為當(dāng)前擴(kuò)展結(jié)點,使搜索朝著解空間樹有最優(yōu)解的分支方向快速推進(jìn),以便快速找到問題的最優(yōu)解。優(yōu)先隊列式分支限界法基本思想(1)確定合理的限界函數(shù),并根據(jù)限界函數(shù)確定問題的目標(biāo)函數(shù)的上(下)界,又稱耗費函數(shù)值或代價值。(2)初始化一個空的優(yōu)先隊列H,并將初始狀態(tài)加入隊列。初始化一個變量best_score用于保存當(dāng)前找到的最優(yōu)解(初值=無窮大)。(3)當(dāng)隊列H不為空時,執(zhí)行以下步驟:優(yōu)先隊列式分支限界法基本思想

①出隊結(jié)點保存為node。

②ifnode結(jié)點對應(yīng)更優(yōu)的解then更新當(dāng)前最優(yōu)解best_score的值。③fornode的每一個子結(jié)點child:a.計算child結(jié)點的目標(biāo)函數(shù)限界值。

b.if

child滿足解的約束條件且耗費函數(shù)值不超過

目標(biāo)函數(shù)的當(dāng)前限界thenc.將child加入隊列H。(4)重復(fù)(3)直到隊列H為空(5)返回這時的best_score作為最優(yōu)解。計算機算法設(shè)計與分析第7章分支限界法7.3.1裝載問題一個農(nóng)場需要將大量農(nóng)產(chǎn)品運輸?shù)绞袌錾先ィ僭O(shè)農(nóng)場現(xiàn)有n種不同的農(nóng)產(chǎn)品和一輛載重量為c的車輛,農(nóng)產(chǎn)品i的重量為wi,價值為vi,每種農(nóng)產(chǎn)品只有裝車和不裝車兩種選擇。如何選擇裝入車輛的農(nóng)產(chǎn)品,使得車輛不超重的情況下一次裝下的農(nóng)產(chǎn)品總重量最大。

7.3.1裝載問題以n=4種農(nóng)產(chǎn)品為例,車輛載重量c=10,每種農(nóng)產(chǎn)品的重量W={6,7,2,4},即w1=6,w2=7,w3=2,w4=4。4種農(nóng)產(chǎn)品的裝載可以表示為一個四元組X=(x1,x2,x3,x4),xi代表第i種農(nóng)產(chǎn)品裝車的數(shù)量,由于每種農(nóng)產(chǎn)品裝載只有裝與不裝兩種情況,所以xi(i=1,2,3,4,表示農(nóng)產(chǎn)品種編號)只能等于0或1,其中0表示不裝車,1表示轉(zhuǎn)入車輛。

裝載問題4類農(nóng)產(chǎn)品裝載問題的解向量空間樹如圖所示

裝載問題c:表示車輛的載重量。xi:表示第i種農(nóng)產(chǎn)品裝入車輛的數(shù)量,取值0或1。wi:表示第i種農(nóng)產(chǎn)品的重量。wt:表示當(dāng)前已裝入車的農(nóng)產(chǎn)品總重量。bestw:表示當(dāng)前車上裝載的農(nóng)產(chǎn)品重量的最優(yōu)值。[wt,k]:表示解空間樹上一個結(jié)點的狀態(tài),即從第1種農(nóng)產(chǎn)品到第k種農(nóng)產(chǎn)品完成裝載選擇時,該結(jié)點表示的車輛上農(nóng)產(chǎn)品總重量為wt。Wt(X):表示解向量X時,車輛裝載的農(nóng)產(chǎn)品總重量。

裝載問題給定任意狀態(tài)[wt,k],怎么來判斷其子結(jié)點是否可能得出可行解?約束函數(shù)剪枝過程約束函數(shù)剪枝過程擴(kuò)展A結(jié)點的左子結(jié)點,xk+1=1,wt’=wt+wk+1,如果這時wt’>c,說明裝入車輛的農(nóng)產(chǎn)品重量超過了車輛的載重量,顯然這時不可行的,需要被剪枝處理。而擴(kuò)展A結(jié)點的右子結(jié)點,xk+1=0,wt≤c,裝載的農(nóng)產(chǎn)品重量與父結(jié)點A是一樣的,因此擴(kuò)展右子結(jié)點總是可行的。裝載問題給定任意狀態(tài)[wt,k],怎么來判斷其子結(jié)點是否可能得出最優(yōu)解?限界函數(shù)剪枝過程:限界函數(shù)擴(kuò)展A結(jié)點的右子結(jié)點,xk+1=0,其右子結(jié)點B的狀態(tài)為[wt,k+1]。限界函數(shù)設(shè)裝載問題的解向量為X=[X1,X2],其中X1=[x1,x2,...,xk,0],X2=[xk+2,...,xn]。X1表示第1種農(nóng)產(chǎn)品到第k+1種農(nóng)產(chǎn)品的裝車情況,是目前已得到的農(nóng)產(chǎn)品裝車結(jié)果;X2表示從第k+2種農(nóng)產(chǎn)品到第n種農(nóng)產(chǎn)品的裝車情況,是還未考慮過的未知裝車結(jié)果。限界函數(shù)對于解向量X裝載農(nóng)產(chǎn)品的總重量:第1種農(nóng)產(chǎn)品到第k+1種農(nóng)產(chǎn)品裝入車后的重量為Wt(X1)=wt;第k+2種農(nóng)產(chǎn)品到第n種農(nóng)產(chǎn)品裝入車后的重量是未知的,用Wt(X2)表示。限界函數(shù)我們只能去估計Wt(X2)值的一個上界bound(X2),上界函數(shù)bound(X2)≥Wt(X2)。bestw表示當(dāng)前已得到的最優(yōu)值,如果Wt(X1)+bound(X2)≤bestw,則表示當(dāng)前已裝車的農(nóng)產(chǎn)品總重量加上未裝車農(nóng)產(chǎn)品重量的上界值比當(dāng)前已知的最優(yōu)解值還要小。因此,可以判定以A為根的結(jié)點擴(kuò)展其右子結(jié)點是不可能得到問題的最優(yōu)解的,可以剪去A結(jié)點的右分支。限界函數(shù)那么,如何來估算bound(X2)呢?我們可以將未裝車的農(nóng)產(chǎn)品全部裝入,得到bound(X2)=這就是限界函數(shù)剪枝過程。限界函數(shù)限界函數(shù)分析過程,對于bestw值什么時候去獲取?如果按照回溯算法分析過程,當(dāng)?shù)玫絾栴}第一個完整解向量時,將這個可行解的值記作第一個bestw的值。但是,得到完整向量的可行解需要搜索到解空間樹的葉子結(jié)點才能完成。限界函數(shù)對于基于廣度優(yōu)先搜索的分支限界法,只能對后續(xù)的葉子結(jié)點進(jìn)行限界函數(shù)剪枝,而剪枝對于葉子結(jié)點來說已經(jīng)沒有實際意義。因此,這樣獲取的bestw無實際效果。限界函數(shù)實際上,我們在擴(kuò)展任意結(jié)點k的左分支時,若其左分支是一個可行解,我們將該左子結(jié)點之后的農(nóng)產(chǎn)品裝載全部選擇不裝車,也可以得到一個完整的解向量,即[x1,,...,xk,1,{0}]。我們可以以這樣一個可行解的值作為bestw的值,因此,在擴(kuò)展左分支時,只要可行(車輛不超重),就及時更新bestw的值。裝載問題的約束限界函數(shù)(1)進(jìn)入左分支的約束函數(shù):wt+wk+1≤c(2)進(jìn)入右分支的限界函數(shù):wt+bound>bestw實例采用隊列式分支限界法搜索n=4種農(nóng)產(chǎn)品(c=10,W={6,7,2,4},農(nóng)產(chǎn)品種編號1~4)的裝載問題,隊列中的結(jié)點元素如下列步驟中的各個圖所示。我們來定義一個結(jié)點元素(wt,bound,k):wt已裝入車了農(nóng)產(chǎn)品的重量bound剩余未裝車農(nóng)產(chǎn)品的總重量k當(dāng)前被處理農(nóng)產(chǎn)品種編號n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}

左子結(jié)點采用約束函數(shù)wt≤c=10作為剪枝策略右子結(jié)點采用限界函數(shù)wt+bound>bestw作為剪枝策略(1)初始結(jié)點1的三個數(shù)據(jù)項值為(0,19,0),即wt=0,bound=19,k=0。bestw初值為0。初始結(jié)點1入隊。1(0,19,0)n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}(2)取隊首結(jié)點1,擴(kuò)展它的左子結(jié)點2,wt=6<10,滿足約束條件是可行的,x1=1,結(jié)點2的三個數(shù)據(jù)項值為(6,13,1),結(jié)點2入隊,同時修改bestw=6。然后再來擴(kuò)展1的右子結(jié)點3,wt+bound=0+19>bestw=6,滿足限界條件是可行的,x1=0,結(jié)點3的三個數(shù)據(jù)項為(0,13,1),結(jié)點3入隊。左右子結(jié)點擴(kuò)展完畢,隊首結(jié)點1出隊。之后隊列情況:2(6,13,1),3(0,13,1)n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}(3)取隊首元素結(jié)點2,擴(kuò)展它的左子結(jié)點4,wt=6+7=13>10,不滿足約束條件,是不可行的,結(jié)點4被剪枝處理。然后再來擴(kuò)展它的右子結(jié)點5,wt+bound=6+6>bestw,滿足限界條件是可行的,x2=0,結(jié)點5的三個數(shù)據(jù)項為(6,6,2),結(jié)點5入隊。左右子結(jié)點擴(kuò)展完畢,隊首結(jié)點2出隊。之后隊列情況:3(0,13,1),5(6,6,2)n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}(4)取隊首結(jié)點3,擴(kuò)展它的左子結(jié)點6,wt=0+7<10,滿足約束條件是可行的,x2=1,結(jié)點6的三個數(shù)據(jù)項值為(7,6,2),結(jié)點6入隊,同時修改bestw=7。然后再來擴(kuò)展它的右子結(jié)點7,wt+bound=0+6<bestw=7,不滿足限界條件,是不可能產(chǎn)生最優(yōu)解的,結(jié)點7被剪枝處理。左右子結(jié)點擴(kuò)展完畢,隊首結(jié)點3出隊。之后隊列情況:5(6,6,2),6(7,6,2)n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}(5)取隊首結(jié)點5,擴(kuò)展它的左子結(jié)點10,wt=6+4=10,滿足約束條件是可行的,x3=1,結(jié)點10的三個數(shù)據(jù)項值為(10,2,3),結(jié)點10入隊,同時修改bestw=10。然后再來擴(kuò)展它的右子結(jié)點11,wt+bound=6+2<bestw=10,不滿足限界條件,是不可能產(chǎn)生最優(yōu)解的,結(jié)點11被剪枝處理。左右子結(jié)點擴(kuò)展完畢,隊首結(jié)點5出隊。之后隊列情況:6(7,6,2),10(10,2,3)n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}(6)取隊首結(jié)點6,擴(kuò)展它的左子結(jié)點12,wt=7+4>10,不滿足約束條件,是不可行的,結(jié)點12被剪枝處理。然后再來擴(kuò)展它的右子結(jié)點13,wt+bound=7+2<bestw=10,不滿足限界條件,是不可能產(chǎn)生最優(yōu)解的,結(jié)點13被剪枝處理。左右子結(jié)點擴(kuò)展完畢,隊首結(jié)點6出隊。之后隊列情況:10(10,2,3)n=4種農(nóng)產(chǎn)品:c=10,W={6,7,2,4}(7)取隊首結(jié)點10,擴(kuò)展它的左子結(jié)點20,wt=10+2>10,不滿足約束條件,是不可行的,結(jié)點20被剪枝處理。然后再來擴(kuò)展它的右子結(jié)點21,wt+bound=10+0=bestw=10,是一個最優(yōu)解的,結(jié)點21(10,0,4)為葉子結(jié)點,結(jié)點21入隊。左右子結(jié)點擴(kuò)展完畢,隊首結(jié)點10出隊。之后隊列情況:21(10,0,4)(8)取隊首結(jié)點21,發(fā)現(xiàn)已為葉子結(jié)點,不用進(jìn)行結(jié)點擴(kuò)展,結(jié)點21直接出隊。(9)隊列為空,循環(huán)結(jié)束。計算機算法設(shè)計與分析第7章分支限界法7.3.2單源最短路徑問題給定帶權(quán)有向圖G=(V,E),其中每條邊的權(quán)是非負(fù)實數(shù).另外,還給定V中的一個頂點,稱為源。現(xiàn)在要計算從源到所有其它各頂點的最短路長度。這里路徑的長度是指路徑上各邊權(quán)之和。這個問題通常稱為單源最短路徑問題。單源最短路徑問題如圖所示的有向圖G,每一條邊都有一個非負(fù)權(quán)值,求源點S到圖中各個結(jié)點之間的最短路徑。算法分析采用優(yōu)先隊列式分支限界法求解單源最短路徑問題,可以構(gòu)建一個基于結(jié)點優(yōu)先級的小根堆來存放活動結(jié)點表:結(jié)點的優(yōu)先級=源點到該結(jié)點的當(dāng)前路徑長度初始時源點到其余個結(jié)點之間距離長度dist[i]設(shè)置為無窮大,當(dāng)然源點本身的dist[S]=0,并將源點S加入優(yōu)先隊列(小根堆)。圖的鄰接矩陣存儲到二維數(shù)組edge內(nèi)。算法分析從小根堆中取出堆頂元作為當(dāng)前擴(kuò)展結(jié)點i,并依次檢查與結(jié)點i相鄰結(jié)點j是否滿足下列條件:dist[i]+edge[i][j]<dist[j]則更新結(jié)點j的優(yōu)先級dist[j]=dist[i]+edge[i][j],并將j結(jié)點加入小根堆(優(yōu)先隊列)。否則被舍去處理。重復(fù)上述過程,直到小根堆(優(yōu)先隊列)為空為止。Sijdist[i]edge[i][j]dist[j]實例(1)開始時小根堆只有源點S,取堆頂元S作為擴(kuò)展結(jié)點,與S相鄰的結(jié)點A,B,C,都滿足更新其優(yōu)先級條件,所以更新A、B、C的優(yōu)先級,將A、B、C結(jié)點加入小根堆,結(jié)點加入小根堆的過程中會重新調(diào)整建堆。dist[A]=dist[S]+edge[S][A]=2dist[B]=dist[S]+edge[S][B]=3dist[C]=dist[S]+edge[S][C]=4此時的解空間樹如下圖所示。SABC實例(2)取小根堆的堆頂元為A結(jié)點,與A相鄰的B、E、F結(jié)點:dist[A]+edge[A][B]>dist[B],剪枝由A擴(kuò)展的B結(jié)點。dist[E]=dist[A]+edge[A][E]=2+2=4dist[F]=dist[A]+edge[A][F]=2+7=9更新結(jié)點E,F的優(yōu)先級并將其加入堆、重新調(diào)整建堆。此時的解空間樹如下圖所示。ABCBCEF實例(3)此時,小根堆(優(yōu)先隊列)的堆頂元為優(yōu)先級最小的結(jié)點B,與B相鄰的C、D、E,只有結(jié)點D滿足優(yōu)先級更新條件而加入到堆,加入堆的過程中會重新調(diào)整建堆。dist[D]=dist[B]+edge[B][D]=3+2=5由B擴(kuò)展的結(jié)點C、E被剪枝舍去。此時的解空間樹如下圖所示。BCEFCDEF實例(4)此時,堆頂元為優(yōu)先級最小的結(jié)點C,取堆頂元C,與C相鄰的結(jié)點D不滿足優(yōu)先級更新條件,剪枝由C擴(kuò)展的結(jié)點D。此時的解空間樹如下圖所示。CDEFEDF實例(5)此時,堆頂元為結(jié)點E,取堆頂元E,與E相鄰的D、H,E擴(kuò)展的結(jié)點D因不滿足優(yōu)先級更新條件被剪枝舍去,dist[H]=dist[E]+edge[E][H]=4+3=7結(jié)點H加入堆。此時的解空間樹如下圖所示。EDFDFH實例(6)取堆頂元結(jié)點D,與D相鄰的結(jié)點I和H,因結(jié)點H不滿足優(yōu)先級更新條件而被舍去,dist[I]=dist[D]+edge[D][H]=5+1=6結(jié)點I更新優(yōu)先級并加入堆。此時的解空間樹如下圖所示。DFHIFH實例(7)此時的堆頂元為結(jié)點I,取堆頂元I,與I相鄰的H、T,因I擴(kuò)展的結(jié)點H不滿足優(yōu)先級更新條件被剪枝舍去dist[T]=dist[I]+edge[I][T]=6+2=8更新結(jié)點T優(yōu)先級并加入堆。此時的解空間樹如圖所示。IFHHFT實例(8)此時,結(jié)點H具有最高優(yōu)先級成為當(dāng)前堆頂元,取堆頂元H,與H相鄰的G、T,由H擴(kuò)展的結(jié)點T不滿足優(yōu)先級更新條件被剪枝舍去;dist[G]=dist[H]+edge[H][G]=7+2=9結(jié)點G加入堆。此時的解空間樹如下圖所示。HFTTFG實例(9)此時,結(jié)點T為小根堆的堆頂元。此時,若問題是求解源點S到終點T的的最短路徑,則已得到問題的解,可以提前結(jié)束循環(huán)。若需要求源點到圖中所有結(jié)點的最短路徑長度,則還需要繼續(xù)執(zhí)行,直到堆(優(yōu)先隊列)為空才結(jié)束循環(huán)。這時取堆頂元T,因T沒有出度邊的鄰結(jié)點,出堆后無操作。此時G成為當(dāng)前堆頂元,擴(kuò)展的結(jié)點T,且不滿足約束條件被剪枝舍去。此時的解空間樹如下圖所示。TFGGFF實例(10)到了此時,優(yōu)先隊列(堆)只剩下一個結(jié)點F,也是當(dāng)前堆頂元,其擴(kuò)展結(jié)點E、H和G,都不滿足更新優(yōu)先級條件被剪枝。此時的解空間樹如下圖所示。F空(11)此時優(yōu)先隊列(堆)為空,循環(huán)結(jié)束,至此單源最短路徑求解全部完成。計算機算法設(shè)計與分析第7章分支限界法7.3.3八數(shù)碼問題280163754123804765初始狀態(tài)

目標(biāo)狀態(tài)

隊列式分支限界法71234589610161718201519111213142

溫馨提示

  • 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論