棧的迷宮求解(數(shù)據(jù)結(jié)構(gòu)試驗(yàn))_第1頁
棧的迷宮求解(數(shù)據(jù)結(jié)構(gòu)試驗(yàn))_第2頁
棧的迷宮求解(數(shù)據(jù)結(jié)構(gòu)試驗(yàn))_第3頁
棧的迷宮求解(數(shù)據(jù)結(jié)構(gòu)試驗(yàn))_第4頁
棧的迷宮求解(數(shù)據(jù)結(jié)構(gòu)試驗(yàn))_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、精選優(yōu)質(zhì)文檔-傾情為你奉上 實(shí)驗(yàn)二:迷宮問題 班級(jí): 姓名: 學(xué)號(hào): 一、 需求分析( 1 ) 以二維數(shù)據(jù)Mazem+2n+2 表示迷宮, 其中: Maze0j 和Mazem+1j(0=j=n+1)及Mazei0和Mazein+1(0=i=m+1)為添加一圈障礙。數(shù)組中以元素值為0 表示通路,1 表示障礙,限定迷宮的大小m,n=0數(shù)據(jù)關(guān)系:R1=|ai-1,aiD,i=2,n基本操作:InitStack(&S)操作結(jié)果:構(gòu)造一個(gè)空棧S。DestroyStack(&S)初始條件:棧S 已存在。操作結(jié)果:銷毀棧S。ClearStack(&S)初始條件:棧S 已存在。操作結(jié)果:將 S 清為空棧。St

2、ackLength(&S)初始條件:棧S 已存在。操作結(jié)果:返回棧 S 的長度。StackEmpty(&S)初始條件:棧S 已存在。操作結(jié)果:若 S 為空棧,則返回TRUE,否則返回FALSE。GetTop(S,&e)初始條件:棧S 已存在。操作結(jié)果:若棧 S 不空,則以e 返回棧頂元素。Push(&S,e)初始條件:棧S 已存在。操作結(jié)果:在棧 S 的棧頂插入新的棧頂元素e。Pop(&S,&e)初始條件:棧S 已存在。操作結(jié)果:刪除 S 的棧頂元素,并以e 返回其值。StackTraverse(S,visit()初始條件:棧S 已存在。操作結(jié)果:從棧底到棧頂依次對 S 中的每個(gè)元素調(diào)用函數(shù)v

3、isit( )。ADT Stack2. 設(shè)定迷宮的抽象數(shù)據(jù)類型為:ADT maze數(shù)據(jù)對象:D=ai,j|ai,j 、#、*,0im+1,0jn+1,m,n10數(shù)據(jù)關(guān)系:R=ROW,COLROW=|ai-1,j,ai,jD,i=1,,m+1,j=0,,n+1COL=|ai,j-1,ai,jD,i=0,,m+1,j=1,,n+1基本操作:InitMaze(&M,a,row,col)初始條件:二維數(shù)組arow+2col+2已存在,其中自第1 行至第row+1行、每行中自第1 列至第col+1 列的元素已有值,并且以值0表示通路,以值1 表示障礙。操作結(jié)果:構(gòu)成迷宮的字符型數(shù)組,以字符6表示通路,以

4、字符41表示障礙,并在迷宮四周加上一圈障礙。MazePath(&M)初始條件:迷宮M 已被賦值,鏈棧S已經(jīng)存在。操作結(jié)果:若迷宮M 中存在一條通路,則按如下規(guī)定改變迷宮M 的狀態(tài):以字符“6”表示路徑上的位置,字符“4”表示“死胡同”;否則迷宮的狀態(tài)不變。PrintMaze(M)初始條件:迷宮M 已存在。操作結(jié)果:以字符形式輸出迷宮。ADT maze;3. 本程序包含三個(gè)模塊1) 主程序模塊:void main( )初始化;do接受命令;處理命令;while(命令!=“退出”);2) 棧模塊實(shí)現(xiàn)棧抽象數(shù)據(jù)類型3) 迷宮模塊實(shí)現(xiàn)迷宮抽象數(shù)據(jù)類型各模塊之間的調(diào)用關(guān)系如下:4. 求解迷宮中一條通路的

5、偽碼算法:設(shè)定當(dāng)前位置的初值為入口位置;do若當(dāng)前位置可通,則將當(dāng)前位置插入棧頂; /納入路徑若該位置是出口位置,則結(jié)束; /求得路徑存放在棧中否則切換當(dāng)前位置的東鄰方塊為新的當(dāng)前位置;否則若棧不空且棧位置尚有其他方向未被探索,則設(shè)定新的當(dāng)前位置為沿順時(shí)針方向旋轉(zhuǎn)找到的棧頂位置的下一相鄰塊;若棧不空但棧頂位置的四周均不可通,則刪去棧頂位置; /后退一步,從路徑中刪去該通道塊,主程序模塊迷宮模塊棧模塊若棧不空,則重新測試新的棧頂位置,直到找到一個(gè)可通的相鄰塊或出棧至???;while(棧不空);??照f明沒有路徑存在三、 詳細(xì)設(shè)計(jì)1 坐標(biāo)位置類型typedef structint r,c; /迷宮中

6、行、列的范圍PosType;2 迷宮類型typedef structint a, b;char arrMN; /各位置取值6 ,4,1或0MazeType;void initmaze(MazeType &maze,int m,int n)/按照用戶輸入的m行和n 列的二維數(shù)組(元素值為0 或1)/設(shè)置迷宮的初值,包括加上邊緣一圈的值bool mazepath(MazeType &maze,PosType start,PosType end,SNode *&S)/求解迷宮maze 中,從入口start 到出口end 的一條路徑/若存在,則返回TRUE;否則返回FALSEvoid printmaz

7、e(mazetype maze)/將迷宮以字符型方陣的形式輸出到標(biāo)準(zhǔn)輸出文件上3 棧類型typedef structint step; /當(dāng)前位置在路徑上的“序號(hào)”PosType position; /當(dāng)前的坐標(biāo)位置int dir; /往下一坐標(biāo)位置的方向ElemType; /棧的元素類型struct SNodeElemType data;SNode *next; /結(jié)點(diǎn)類型,指針類型棧的基本操作設(shè)置如下:void InitStack(Stack &S)/初始化,設(shè)S 為空棧(S.top=NULL)并返回TRUE,否則返回FALSEStatus Push(Stack &S,ElemType e

8、)/若分配空間成功,則在S 的棧頂插入新的棧頂元素e,并返回TRUE;/否則棧不變,并返回FALSEStatus Pop(Stack &S,ElemType &e)/若棧不空,則刪除S 的棧頂元素并以e 帶回其值,且返回TRUE/否則返回FALSEvoid print(SNode *S) /輸出棧的內(nèi)容其中該程序的C+全部代碼如下:#includeusing namespace std;#define n 10#define m 10/迷宮各設(shè)置函數(shù)void print(char mazenm)for (int i=0;in;i+)for(int j=0;jm;j+)coutmazeij ;c

9、outendl;void add_maze(char mazenm) int a,b,c; for(a=1;a=(n-2)*(m-2);a+) cout障礙位置為(1=i=n-1;1=j=m-1bc; if(b=0&c=0) cout設(shè)置完成endl; break; if(b=0|c=n|c=m) cout輸入錯(cuò)誤endl; break; mazebc=1; void create_maze( char mazenm)int i=0,j=0;/為迷宮加圍墻for(j=0;jm;j+)maze0j=1;mazen-1j=1;for(i=0;in;i+)mazei0=1;mazeim-1=1; /

10、設(shè)圍墻內(nèi)所有點(diǎn)為通路for(i=1;in-1;i+) for(j=1;jm-1;j+)mazeij=0; print(maze);/輸出造好的迷宮 add_maze(maze);/增加迷宮障礙 coutendl;print(maze);/再次輸出此時(shí)造好的迷宮/迷宮棧應(yīng)用struct Node int i,j;struct StackNode pos;Stack *next;void InitStack(Stack *&S)Stack *p;cout開辟一個(gè)新棧next=NULL;S-next=p;couthas created.pos.i=a; p-pos.j=b;p-next=S-next

11、;S-next=p;mazeab=Y;void pop(Stack *&S,char mazenm)/出棧及相關(guān)操作if(!S-next) coutthe stack is empty!next-pos.iS-next-pos.j=N; S-next=S-next-next; void Walking(Stack *&S,char mazenm,int i,int j)if(i=n-2 & j=m-2) return; /表示已經(jīng)到達(dá)終點(diǎn)if(mazeij+1!=1 & mazeij+1!=Y & mazeij+1!=N)/向東走,if判斷包括下一個(gè)位置是否是墻(1),是否是已經(jīng)走過的路(Y)

12、(N)j+;push(S,maze,i,j);Walking(S,maze,i,j);return;if(mazei+1j!=1 & mazei+1j!=Y & mazei+1j!=N)/向南走i+;push(S,maze,i,j);Walking(S,maze,i,j);return;if(mazeij-1!=1 & mazeij-1!=Y & mazeij-1!=N)/向西走j-;push(S,maze,i,j);Walking(S,maze,i,j);return;if(mazei-1j!=1 & mazei-1j!=Y & mazei-1j!=N)/向北走i-;push(S,maze,

13、i,j);Walking(S,maze,i,j);return; pop(S,maze);/四個(gè)方向都不通,說明該點(diǎn)無法到達(dá)終點(diǎn),實(shí)行出棧i=S-next-pos.i;j=S-next-pos.j;Walking(S,maze,i,j);void games(Stack *&S,char mazenm)int i=1,j=1;push(S,maze,i,j);/先把第一個(gè)起始點(diǎn)入棧Walking(S,maze,i,j);/遞歸算法if(!S-next)cout該迷宮是死胡同endl;else cout該迷宮可走通next=NULL; InitStack(S); games(S,maze); /

14、為方便DevC+可以看到最后運(yùn)行的結(jié)果,故設(shè)此輸入 coutsui; return 0;四、 調(diào)試分析1本次作業(yè)比較簡單,只有一個(gè)核心算法,即求迷宮的路徑,所以總的調(diào)試比較順利,只在調(diào)試MazePath 算法時(shí),遇到兩個(gè)問題:其一是,起初輸出的迷宮中沒有加上4的記號(hào),后發(fā)現(xiàn)是因?yàn)樵贛arkPrint 函數(shù)中的迷宮參數(shù)丟失“變參”的原因;其二是,由于回退時(shí)沒有將curpos 隨之減一,致使棧中路徑上的序號(hào)有錯(cuò)。2棧的元素中的step 域沒有太多用處,可以省略。3StackTraverse 在調(diào)試過程中很有用,它可以插入在MazePath 算法中多處,以察看解迷宮過程中走的路徑是否正確,但對最后的

15、執(zhí)行版本沒有用。4本題中三個(gè)主要算法:InitMaze,MazePath 和PrintMaze 的時(shí)間復(fù)雜度均為0(a*b),本題的空間復(fù)雜度亦為0(a*b)(棧所占最大空間)5經(jīng)驗(yàn)體會(huì):借助DEBUG 調(diào)試器和數(shù)據(jù)觀察窗口,可以加快找到程序中疵點(diǎn)。五、 用戶手冊1 本程序的運(yùn)行環(huán)境為xp,w7 操作系統(tǒng),執(zhí)行文件為:迷宮問題.exe.2 進(jìn)入演示程序后,即現(xiàn)實(shí)文本方式的用戶界面:主程序Initialization ReadCommand InterpretInitMaze MazePath PrintMazeInitStack Push Pop StackEmpty StackTraverse FootPrint MarkPrint Pass NextPos 3 進(jìn)入“產(chǎn)生迷宮(maze

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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ǔ)空間,僅對用戶上傳內(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

提交評論