密頓回路問題的回溯算法_第1頁
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡介

1、 哈密頓回路問題: 解空間: A= (x1, x2, , xn)| x1=1, 2= xi=n, i= 2, , n其中,x1, x2, , xn表示G中的頂點(diǎn)序列。 解的約束條件:(設(shè)圖G用鄰接矩陣graph表示)(x1, x2, , xn)為哈密頓回路當(dāng)且僅當(dāng)graphxk-1, xk=1, k=2, 3, , n 且graphxn, x1=1且xixj (ij) 回溯算法:設(shè)置一個(gè)標(biāo)記數(shù)組tag1.n表示頂點(diǎn)是否在當(dāng)前生成的路徑上: tagi=1, 頂點(diǎn)i在當(dāng)前路徑上 tagi=0, 頂點(diǎn)i不在當(dāng)前路徑上注意:當(dāng)一個(gè)頂點(diǎn)退出當(dāng)前路徑時(shí),該頂點(diǎn)的標(biāo)記應(yīng)復(fù)原為0。算法 HAMILTONIAN

2、輸入:正整數(shù)n和含n個(gè)頂點(diǎn)的連通圖G的鄰接矩陣graph。輸出:圖G的所有哈密頓回路, 若無哈密頓回路則輸出no solution。 x1=1 ; x2.n=0 /用x1.n表示搜索路徑, 從頂點(diǎn)1開始。tag1=1; for i=2 to n tagi=0/設(shè)頂點(diǎn)標(biāo)記初值。flag=hamilton( 2 )if not flag then output “no solution”/輸出無解 end HAMILTONIAN 過程 hamilton(k) /在已得到當(dāng)前路徑x1.k-1的情況下,求圖G的所有哈密 /頓回路并輸出,有解則返回true, 否則返回false。 t=false /用t

3、標(biāo)志是否有解。for i=2 to nxk=i /試將頂點(diǎn)i作為當(dāng)前路徑上的第k個(gè)頂點(diǎn)。 if route(k) then /當(dāng)前頂點(diǎn)可作為當(dāng)前路徑的下一頂點(diǎn)。 tagxk=1 /當(dāng)前頂點(diǎn)加入當(dāng)前路徑。if k=n then /找到一條哈密頓回路。 t=true;output x1.n /輸出當(dāng)前找到的哈密頓回路。else /x1.k是部分路徑。 t1= hamilton (k+1) /遞歸求后面所有的哈密頓回路 if t1 then t=true end iftagxk=0 /頂點(diǎn)xk退出當(dāng)前路徑。 end if end for return tend hamilton過程 route(k) /判斷當(dāng)前頂點(diǎn)xk是否可作為當(dāng)前路徑x1.k-1的下一頂點(diǎn), /是則返回true, 否則返回false。if (graphxk-1, xk=1)and (tagxk=0)and(kn or k=n and gra

溫馨提示

  • 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論