lab6-回溯算法設計與應用_第1頁
已閱讀1頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、實驗六實驗六回溯算法設計與應用回溯算法設計與應用一基本原理的概括一基本原理的概括DFS剪枝(在狀態(tài)空間樹上作帶剪枝的DFS搜索)?剪枝:若搜索到某結點,其對應的部分解不滿足解的約束條件且可斷定以其為根的子樹上不包含答案結點,則不搜索該子樹,直接回到其父結點,繼續(xù)DFS。利用回溯法可求問題的一個解,多個解,所有解,最優(yōu)解,還可判斷解的存在性。二該類算法設計與實現(xiàn)的要點二該類算法設計與實現(xiàn)的要點回溯法通常包含以下3個步驟:1)定義給定問題的

2、解空間;2)確定并表示解的約束條件和其它的剪枝條件;3)結合剪枝深度優(yōu)先搜索相應的狀態(tài)空間樹。注意:回溯法的一個特征是在搜索過程中動態(tài)的產生問題的狀態(tài)空間樹,任何時候只存根到當前搜索的結點的路徑。三實驗目的和要求三實驗目的和要求理解回溯法的基本原理,掌握回溯法設計的基本方法及步驟,并應用于具體問題的解決。四實驗內容四實驗內容(一)馬的周游問題馬的周游問題1.1.問題描述問題描述在nxn棋盤(有nxn個格點的棋盤)的某個格點上有一個中國象

3、棋馬,馬走日字。求一條周游棋盤的路徑,使得馬能夠從起始位置起沿著該路徑每個格點恰好走一次最后回到出發(fā)位置。2.具體要求具體要求用回溯法解決該問題。輸入一個正整數(shù)n,輸出一個解,解的輸出形式盡可能直觀。3.3.設計與實現(xiàn)設計與實現(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)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論