版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、實驗六實驗六回溯算法設(shè)計與應(yīng)用回溯算法設(shè)計與應(yīng)用一基本原理的概括一基本原理的概括DFS剪枝(在狀態(tài)空間樹上作帶剪枝的DFS搜索)?剪枝:若搜索到某結(jié)點,其對應(yīng)的部分解不滿足解的約束條件且可斷定以其為根的子樹上不包含答案結(jié)點,則不搜索該子樹,直接回到其父結(jié)點,繼續(xù)DFS。利用回溯法可求問題的一個解,多個解,所有解,最優(yōu)解,還可判斷解的存在性。二該類算法設(shè)計與實現(xiàn)的要點二該類算法設(shè)計與實現(xiàn)的要點回溯法通常包含以下3個步驟:1)定義給定問題的
2、解空間;2)確定并表示解的約束條件和其它的剪枝條件;3)結(jié)合剪枝深度優(yōu)先搜索相應(yīng)的狀態(tài)空間樹。注意:回溯法的一個特征是在搜索過程中動態(tài)的產(chǎn)生問題的狀態(tài)空間樹,任何時候只存根到當前搜索的結(jié)點的路徑。三實驗?zāi)康暮鸵笕龑嶒災(zāi)康暮鸵罄斫饣厮莘ǖ幕驹?,掌握回溯法設(shè)計的基本方法及步驟,并應(yīng)用于具體問題的解決。四實驗內(nèi)容四實驗內(nèi)容(一)馬的周游問題馬的周游問題1.1.問題描述問題描述在nxn棋盤(有nxn個格點的棋盤)的某個格點上有一個中國象
3、棋馬,馬走日字。求一條周游棋盤的路徑,使得馬能夠從起始位置起沿著該路徑每個格點恰好走一次最后回到出發(fā)位置。2.具體要求具體要求用回溯法解決該問題。輸入一個正整數(shù)n,輸出一個解,解的輸出形式盡可能直觀。3.3.設(shè)計與實現(xiàn)設(shè)計與實現(xiàn)代碼如下:代碼如下:#include#include#include#include#include#include#include#includeusingusingnamespacenamespacestds
4、tdinlineinlineintintgood(intgood(intxintxintyintyints[30][30]ints[30][30]intn)n)if(x=01elseelsereturnreturn00voidvoidmain()main()intintflag=1flag=1while(flag=1)while(flag=1)coutendlcoutendlcout“1cout“1、開始求解、開始求解“endl“2“e
5、ndl“2、退出、退出“endl“endlcoutendlcoutendlcout“cout“請輸入您的選項請輸入您的選項(1(12)2)“endl“endlelseelseif(d[m]==d21yd[m]=d11s[y][x]=wnumif(d[m]==d21yd[m]=d11s[y][x]=wnumelseelseif(d[m]==d22y=y2d[m]=d11s[y][x]=wnumif(d[m]==d22y=y2d[m]=d1
6、1s[y][x]=wnumelseelseif(d[m]==d31y=y2d[m]=d11s[y][x]=wnumy=y2d[m]=d11s[y][x]=wnumelseelseif(d[m]==d32yd[m]=d11s[y][x]=wnum2yd[m]=d11s[y][x]=wnumelseelseif(d[m]==d41yif(d[m]==d41yd[m]=d11s[y][x]=wnumd[m]=d11s[y][x]=wnumel
7、seelseif(d[m]==d42y=yif(d[m]==d42y=y2d[m]=d11s[y][x]=wnum2d[m]=d11s[y][x]=wnumelseelsewhile(d[m]==d42)while(d[m]==d42)mmif(d[m]==d11)s[y][x]=88wxy=y2if(d[m]==d11)s[y][x]=88wxy=y2if(d[m]==d12)s[y][x]=88wx=x2yif(d[m]==d12)
8、s[y][x]=88wx=x2yif(d[m]==d21)s[y][x]=88wx=x2yif(d[m]==d21)s[y][x]=88wx=x2yif(d[m]==d22)s[y][x]=88wxy=y2if(d[m]==d22)s[y][x]=88wxy=y2if(d[m]==d31)s[y][x]=88wxy=y2if(d[m]==d31)s[y][x]=88wxy=y2if(d[m]==d32)s[y][x]=88wx=x2yi
9、f(d[m]==d32)s[y][x]=88wx=x2yif(d[m]==d41)s[y][x]=88wx=x2yif(d[m]==d41)s[y][x]=88wx=x2yif(m!=0wxy=y2if(m!=0wxy=y2d[m]=road(d[m]1)d[m]=road(d[m]1)while((m!=0||d[0]!=d42||good(x1y2sn))x)(qy)(qy)!=5)cout“cout“馬跳之后的情況馬跳之后的情況(
10、數(shù)字表示跳躍先后順序數(shù)字表示跳躍先后順序)“endl)“endlf(i=0ini)f(i=0ini)f(j=0jnj)f(j=0jnj)coutsetfill(0)setw(2)s[i][j]“coutsetfill(0)setw(2)s[i][j]“““coutendlcoutendlcoutendlcoutendlcoutendlcoutendlbreakbreakcasecase2:exit(1)break2:exit(1)bre
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- lab5-貪心算法設(shè)計與應(yīng)用
- lab4-動態(tài)規(guī)劃算法設(shè)計與應(yīng)用
- 回溯法論文-回溯法的分析與應(yīng)用
- 回溯搜索優(yōu)化算法的研究和應(yīng)用.pdf
- 回溯搜索算法的改進及其工程應(yīng)用.pdf
- 基于優(yōu)先級與回溯算法的排課系統(tǒng)的設(shè)計與實現(xiàn).pdf
- 回溯搜索優(yōu)化算法及其在圖像分割中的應(yīng)用.pdf
- 回溯算法案例分析(論文原稿)
- 基于優(yōu)先級回溯算法的高校排課系統(tǒng)設(shè)計與實現(xiàn).pdf
- 方向回溯系統(tǒng)設(shè)計及應(yīng)用研究.pdf
- 慣性-多普勒組合導(dǎo)航回溯算法研究.pdf
- 回溯搜索算法的研究及改進.pdf
- 基于回溯式搜索算法的隨機神經(jīng)網(wǎng)絡(luò)優(yōu)化及應(yīng)用.pdf
- 視頻監(jiān)控算法研究及Lab VIEW實現(xiàn).pdf
- LaB6-ZrB2共晶合金的組織與性能.pdf
- N皇后問題回溯算法探討_張萬軍.pdf
- N皇后問題回溯算法探討_張萬軍.pdf
- 無約束優(yōu)化的回溯信賴域算法.pdf
- 基于最小回溯代價的智能組卷算法.pdf
- 實時預(yù)警算法設(shè)計與應(yīng)用
評論
0/150
提交評論