版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告</p><p> 題 目: 迷宮問題</p><p><b> 一. 設(shè)計目的</b></p><p> (1)熟練掌握鏈棧的基本操作及應(yīng)用。</p><p> (2)利用鏈表作為棧的存儲結(jié)構(gòu),設(shè)計實現(xiàn)一個求解迷宮的非遞歸程序。</p>&l
2、t;p><b> 二. 設(shè)計內(nèi)容</b></p><p> 計算機解迷宮通常用的是“窮舉求解”方法,即從入口出發(fā),順著某一個方向進行探索,若能走通,則繼續(xù)往前進;否則沿著原路退回,換一個方向繼續(xù)探索,直至出口位置,求得一條通路。假如所有可能的通路都探索到則未能到達出口,則所設(shè)定的迷宮沒有通解。</p><p> 可以二維數(shù)組存儲迷宮數(shù)據(jù),通常設(shè)定入口點的
3、下標(biāo)為(1,1),出口點的下標(biāo)為(n,n)。為處理方便起見,可以迷宮的四周加一圈障礙。對于迷宮任一位置,均可約定有東、南、西、北四個方向可通。</p><p><b> 三.概要設(shè)計</b></p><p> 以一個m×n的長方陣表示迷宮,0和1分別表示迷宮中的通路和障礙。設(shè)計一個程序,對信任意設(shè)定的迷宮,求出一條從入口到出口的通路,或得出沒有通路的結(jié)論
4、。</p><p> 首先實現(xiàn)一個鏈表作存儲結(jié)構(gòu)的棧類型,然后編寫一個求解迷宮的非遞歸程序。求得的通路以二元組(i,j)的形式輸出,其中:(i,j)指示迷宮中的一個坐標(biāo)。如:對于下列數(shù)據(jù)的迷宮,輸出的一條通路為:(1,1),(1,2),(2,2),(3,2),(3,1),……</p><p><b> 1.功能模塊圖;</b></p><p&g
5、t;<b> 數(shù)據(jù)結(jié)構(gòu)</b></p><p> int mark[N][M] = {0};/*初始化標(biāo)志位,0代表沒走過,1代表走過*/ </p><p><b> /*方向*/ </b></p><p> typedef struct{ </p><p> short int vert
6、; </p><p> short int horiz; </p><p> }offsets; </p><p> offsets move[4] = {{0,1},{1,0},{0,-1},{-1,0}};/*北,東,南,西*/ </p><p><b> /*迷宮類型*/ </b></p>&
7、lt;p> typedef struct { </p><p> short int row; </p><p> short int col; </p><p> short int dir; </p><p> }element; </p><p> element stack[MAX];<
8、/p><p><b> 各個函數(shù)</b></p><p> element del(int* top)//出棧,top指向棧頂元素</p><p> void add(int* top,element item)/*入棧*/</p><p> void path(void)/*迷宮函數(shù)*/</p>&l
9、t;p> 2.各個模塊詳細的功能描述。</p><p> 出棧函數(shù),top指向棧頂元素</p><p> 入棧函數(shù),將可走的路徑入棧</p><p><b> 迷宮函數(shù),進行尋路</b></p><p><b> 模塊層次調(diào)用關(guān)系圖</b></p><p>&
10、lt;b> 四.詳細設(shè)計</b></p><p> while(top > -1 && !found) </p><p><b> { </b></p><p> position= del(&top); /*將棧頂元素取出,*/ </p><p> row =
11、 position.row; /*利用中間變量row,col,dir等候判斷*/ </p><p> col = position.col; </p><p> dir = position.dir; </p><p> while(dir < 4 && !found) </p><p>&l
12、t;b> { </b></p><p> next_row = row + move[dir].vert; </p><p> next_col = col + move[dir].horiz; </p><p> if(row == 9&& col == 8) //判斷是否找到終點</p><p>
13、 found = 1; </p><p> else if(!maze[next_row][next_col] && !mark[next_row][next_col])/*判斷下一步可走并且沒走過,則入棧*/ </p><p><b> { </b></p><p> mark[next_row][next_col]
14、= 1; </p><p> position.row = row; </p><p> position.col = col; </p><p> position.dir = ++dir; </p><p> add(&top,position);/*合理則入棧*/ </p><p> row =
15、 next_row;/*繼續(xù)向下走*/ </p><p> col = next_col;</p><p><b> dir = 0; </b></p><p><b> } </b></p><p><b> else </b></p><p>
16、; dir++;/*dir<4時,改變方向*/</p><p> 起點路徑入棧,判斷棧是否滿了,并且是否找到出口,將棧頂元素去除,利用中間變量row,col,dir等候判斷,首先判斷是否找到終點,選擇北,東,南,西四個方向,offsets move[4] = {{0,1},{1,0},{0,-1},{-1,0}};,運用這個轉(zhuǎn)換方向,判斷下一步可走并且沒走過,則入棧,可走的話,標(biāo)志數(shù)組標(biāo)志為1,合理可走
17、則入棧,繼續(xù)往下走,不合理則dir++,進行下次判斷。四個方向都走不通的話,棧頂元素出棧,繼續(xù)進行下面的判斷,直到找到終點或者走不通。</p><p> 找到終點后,倒序打印棧里的元素,就是路徑,并保存。</p><p> 五.測試數(shù)據(jù)及運行結(jié)果</p><p> 1.正常測試數(shù)據(jù)和運行結(jié)果</p><p> int maze[N][
18、M] =</p><p> { {1,1,1,1,1,1,1,1,1,1},</p><p> {1,0,0,1,0,0,0,1,0,1},</p><p> {1,0,0,1,0,0,0,1,0,1},</p><p> {1,0,0,0,0,1,1,0,1,1},</p><p> {1,0,1,1,1
19、,0,0,1,0,1},</p><p> {1,0,0,0,1,0,0,0,0,1},</p><p> {1,0,1,0,0,0,1,0,1,1},</p><p> {1,0,1,1,1,1,0,0,1,1},</p><p> {1,1,1,0,0,0,1,0,1,1},</p><p> {1,1,
20、1,0,0,0,0,0,0,1},</p><p> {1,1,1,1,1,1,1,1,1,1},</p><p> };/*初始化迷宮*/</p><p> 2.異常測試數(shù)據(jù)及運行結(jié)果</p><p> int maze[N][M] =</p><p> { {1,1,1,1,1,1,1,1,1,1},&
21、lt;/p><p> {1,0,0,1,0,0,0,1,0,1},</p><p> {1,0,0,1,0,0,0,1,0,1},</p><p> {1,0,0,0,0,1,1,0,1,1},</p><p> {1,0,1,1,1,0,0,1,0,1},</p><p> {1,0,0,0,1,0,0,0,0
22、,1},</p><p> {1,0,1,0,0,0,1,0,1,1},</p><p> {1,0,1,1,1,1,0,0,1,1},</p><p> {1,1,1,0,0,0,1,0,1,1},</p><p> {1,1,1,0,0,0,0,0,0,1},</p><p> {1,1,1,1,1,1,
23、1,1,1,1},</p><p> };/*初始化迷宮*/</p><p> 六.調(diào)試情況,設(shè)計技巧及體會</p><p> 調(diào)試比較順利,幾乎沒有出現(xiàn)什么重大問題,在和同學(xué)的討論之后,改進了算法。</p><p><b> 1.改進方案</b></p><p> 在對文件的存儲方面,
24、有一些不足,存儲出來的東西,也只是一些數(shù)字,不能很好地讀取。</p><p> 在對迷宮的生成方面,也有一些不足,只是能簡單地初始化迷宮。</p><p><b> 2.體會</b></p><p> 剛開始主要是在尋找路徑那里遇到了很多問題,起初我用一個棧來比較符合通路的坐標(biāo),實現(xiàn)起來很費力。在返回值進出棧時又碰到麻煩,就是top=to
25、p->next和return top->data這兩個地方,有時沒出錯了但就是不能運行出結(jié)果。改了很久也糾正不過來,在同學(xué)給的建議下,position.dir = ++dir;,實現(xiàn)了。。</p><p> 在輸出路徑時,怎么標(biāo)記當(dāng)前位置的四個方向也是一個難題。我就在考慮怎么指向才是正確的,通過不斷實踐,認(rèn)為用路徑出棧時已出棧的坐標(biāo)和棧頂值的差值可以正確的確定路徑的方向,把它倒退回去看就可以了。&l
26、t;/p><p> 對棧的理解,也有了一定的加深,遺憾的是,沒有寫其他兩個程序,有空一定把它們完成要能很好的掌握編程僅僅通過幾個簡單的程序的編寫是無法達成的更需要大量積和深入有可能就從這個迷宮的問題來說在搜索的算法來解決兩點間最短路徑問題在程序的編寫中也不能一味得向已有的程序進行模仿而要自己去摸索去尋求最好的解決方式只有帶著問題去反復(fù)進行實踐才能更熟練的掌握和運用當(dāng)對現(xiàn)有的程序也要多去接觸因為有些程序是我們無法在短
溫馨提示
- 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)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 迷宮問題課程設(shè)計報告
- 迷宮問題課程設(shè)計報告
- 迷宮問題課程設(shè)計報告
- 迷宮問題課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計迷宮問題課程設(shè)計報告
- 迷宮課程設(shè)計報告
- 迷宮課程設(shè)計報告
- 迷宮問題——數(shù)據(jù)結(jié)構(gòu)課程設(shè)計迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告----迷宮問題
- c語言課程設(shè)計--迷宮問題
- 課程設(shè)計(迷宮)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(迷宮問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計—迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)迷宮問題課程設(shè)計
評論
0/150
提交評論