版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p> 計(jì)算機(jī)科學(xué)與技術(shù)學(xué)院</p><p> 課 程 設(shè) 計(jì) 報(bào) 告 </p><p> ( 2007 ~ 2008 學(xué)年度 第 1學(xué)期 )</p><p><b> 1.實(shí)驗(yàn)?zāi)康募耙?lt;/b></p><p> 1)、設(shè)計(jì)目標(biāo)(問題描述)</p><p>&
2、lt;b> 迷宮問題</b></p><p> 問題描述:迷宮實(shí)驗(yàn)是取自心理學(xué)的一個(gè)古典實(shí)驗(yàn)。在該實(shí)驗(yàn)中,把一只老鼠從一個(gè)無頂大盒子的門放入,在盒中設(shè)置了許多墻,對行進(jìn)方向形成了多處阻擋。盒子僅有一個(gè)出口,在出口處放置一塊奶酪,吸引老鼠在迷宮中尋找道路以到達(dá)出口。對同一只老鼠重復(fù)進(jìn)行上述實(shí)驗(yàn),一直到老鼠從入口到出口,而不走錯(cuò)一步。老鼠經(jīng)多次試驗(yàn)終于得到它學(xué)習(xí)走迷宮的路線。</p>
3、<p><b> 2)、功能設(shè)計(jì)要求</b></p><p> 編寫一個(gè)程序求解迷宮問題。迷宮由m行n列的二維數(shù)組設(shè)置,0表示無障礙,1表示有障礙。設(shè)入口為(1,1),出口為(m,n),每次只能從一個(gè)無障礙單元移到周圍四個(gè)方向上任一無障礙單元。編程實(shí)現(xiàn)對任意設(shè)定的迷宮,求出一條從入口到出口的通路,或得出沒有通路的結(jié)論。</p><p> 算法輸入:
4、代表迷宮入口的坐標(biāo)</p><p> 算法輸出:穿過迷宮的結(jié)果。</p><p> 算法要點(diǎn):創(chuàng)建迷宮,試探法查找路徑,輸出解</p><p> 3)、實(shí)驗(yàn)?zāi)康?1、加深對棧特性理解,以便在解決實(shí)際問題中靈活運(yùn)用它們 2、加深對棧操作實(shí)際算法的理解 3、進(jìn)一步熟悉掌握鏈表的操作; 4、掌握指針的應(yīng)用 5、更進(jìn)一步掌握有關(guān)
5、類的操作 </p><p> 4)、 需求分析 1、本程序?qū)崿F(xiàn)迷宮的探索過程. 以用戶和計(jì)算機(jī)對話的方式,即在計(jì)算機(jī)終端上顯示“提示信息”之后,由用戶在鍵盤上輸入演示程序中規(guī)定的運(yùn)算命令,然后
6、程序就探索路徑并輸出路徑。 2、本演示程序中,輸入形式以“回車符”為結(jié)束標(biāo)志,且允許出現(xiàn)重復(fù)字符。 3、利用二維指針實(shí)現(xiàn)迷宮位置的存儲(chǔ),并用棧存貯探索路徑,每個(gè)結(jié)點(diǎn)含三個(gè)整形變量。輸入的形式以回車結(jié)束。 4、本程序中,用戶可以讀去文件里的迷宮,也可自己重新輸入迷宮,而且用戶可以輸入任意大小的迷宮,然后程序自動(dòng)探索路徑,并輸出迷宮的路徑 </p><p> 5)、創(chuàng)新(見源程序附錄)
7、</p><p> 6)、軟件、硬件環(huán)境</p><p> 軟件環(huán)境:Microsoft Windows Xp Processional2002 Service</p><p> Microsoft Visual C++6.0 </p><p> 硬件環(huán)境:cpu:AMD Athlon(tm)64x Dual</p>
8、<p> Processor 3800+2.01GHz Main memory:960MB</p><p><b> 2.實(shí)驗(yàn)步驟</b></p><p> a.認(rèn)真閱讀課本的相關(guān)知識(shí)章節(jié)。</p><p> b.認(rèn)真分析課題的需求分析和功能分析。</p><p> c.根據(jù)分析的思路寫出偽代碼。&
9、lt;/p><p> d.根據(jù)偽代碼上機(jī)編寫程序,進(jìn)行初步調(diào)試。</p><p> e.逐步增加完善系統(tǒng)的功能,實(shí)現(xiàn)人工智能化。</p><p> f.記錄上機(jī)運(yùn)行時(shí)遇到的錯(cuò)誤,進(jìn)行認(rèn)真分析。</p><p> g.最后認(rèn)真撰寫實(shí)驗(yàn)報(bào)告,寫出實(shí)驗(yàn)心得總結(jié)。</p><p><b> 3. 實(shí)驗(yàn)內(nèi)容<
10、;/b></p><p><b> 1)、設(shè)計(jì)概述</b></p><p> (a) 開發(fā)平臺(tái):VC6.0</p><p><b> (b) 參考書籍:</b></p><p> 1.數(shù)據(jù)結(jié)構(gòu)C++描述 熊岳山 陳懷義 編著 國防科技大學(xué)出版社</p><p&g
11、t; 2、《數(shù)據(jù)結(jié)構(gòu)與算法》黃定 黃煜廉 編著 廣東科技出版社 2000年1月第1版</p><p> 3、《數(shù)據(jù)結(jié)構(gòu)輔導(dǎo)與提高》徐孝凱 編著 清華大學(xué)出版社 2003年12月第1版</p><p> (c) 開發(fā)周期: 10天(構(gòu)思3天、雛形3天、修改2天、再修改1天、完善1天)</p><
12、p><b> 2)、處理流程</b></p><p> (a)畫出功能結(jié)構(gòu)圖</p><p> (b)畫出主要數(shù)據(jù)結(jié)構(gòu)的類圖</p><p> (c)主要函數(shù)的程序流程圖</p><p><b> 1.</b></p><p> main函數(shù)流程圖:<
13、/p><p> 2.探索路徑函數(shù)findpath()</p><p> 3.自行輸入迷宮函數(shù)writefile()</p><p> (d)寫出數(shù)據(jù)測試表(輸入數(shù)據(jù)/預(yù)期結(jié)果)</p><p> 測試一:從文件中讀取迷宮: 001000100</p><p><b> 001000101</b&g
14、t;</p><p><b> 000011000</b></p><p><b> 011100100</b></p><p><b> 000100001</b></p><p><b> 010001010</b></p>&l
15、t;p><b> 011110011</b></p><p><b> 110001011</b></p><p><b> 110000000</b></p><p><b> 輸出:</b></p><p> 探索路徑: (1,1,向下
16、) </p><p><b> ?。?,1,向下)</b></p><p><b> (3,1,向下)</b></p><p><b> ?。?,1,向下)</b></p><p><b> ?。?,1,向右)</b></p><p&
17、gt;<b> ?。?,2,向右)</b></p><p><b> ?。?,3,向下)</b></p><p><b> ?。?,3,向右)</b></p><p><b> ?。?,4,向右)</b></p><p><b> (6,5,向
18、上)</b></p><p><b> (5,5,向右)</b></p><p><b> ?。?,6,向右)</b></p><p><b> ?。?,7,向下)</b></p><p><b> (6,7,向下)</b></p&g
19、t;<p><b> ?。?,7,向下)</b></p><p><b> (8,7,向下)</b></p><p><b> ?。?,7,向右)</b></p><p><b> ?。?,8,向右)</b></p><p><b&g
20、t; (9,9)</b></p><p><b> 測試二:</b></p><p><b> 自己輸入迷宮:</b></p><p><b> 001</b></p><p><b> 000</b></p><
21、p><b> 100</b></p><p><b> 輸出探索路徑:</b></p><p><b> ?。?,1,向下)</b></p><p><b> ?。?,1,向右)</b></p><p><b> ?。?,2,向下)&l
22、t;/b></p><p><b> ?。?,2,向右)</b></p><p><b> ?。?,3)</b></p><p><b> 測試三:</b></p><p><b> 自己輸入迷宮:</b></p><p>
23、;<b> 111</b></p><p><b> 111</b></p><p><b> 000</b></p><p><b> 輸出探索路徑:</b></p><p> Sorry!找不到路徑!</p><p>
24、<b> 4.實(shí)驗(yàn)結(jié)果</b></p><p> 結(jié)果為以下三種情形之一:</p><p> 1)編譯不通過:給出編譯錯(cuò)。</p><p> Compiling...</p><p><b> stack.cpp</b></p><p> Skipping...
25、(no relevant changes detected)</p><p><b> main.cpp</b></p><p> Linking...</p><p> stack.obj : error LNK2005: "public: __thiscall stack::stack(void)" (??0sta
26、ck@@QAE@XZ) already defined in main.obj</p><p> stack.obj : error LNK2005: "public: __thiscall stack::~stack(void)" (??1stack@@QAE@XZ) already defined in main.obj</p><p> stack.obj :
27、 error LNK2005: "public: void __thiscall stack::Push(struct DataType)" (?Push@stack@@QAEXUDataType@@@Z) already defined in main.obj</p><p> stack.obj : error LNK2005: "public: struct DataType
28、 __thiscall stack::Pop(void)" (?Pop@stack@@QAE?AUDataType@@XZ) already defined in main.obj</p><p> stack.obj : error LNK2005: "public: struct DataType __thiscall stack::GetPop(void)" (?GetPop
29、@stack@@QAE?AUDataType@@XZ) already defined in main.obj</p><p> stack.obj : error LNK2005: "public: void __thiscall stack::Clear(void)" (?Clear@stack@@QAEXXZ) already defined in main.obj</p>
30、<p> stack.obj : error LNK2005: "public: bool __thiscall stack::IsEmpty(void)" (?IsEmpty@stack@@QAE_NXZ) already defined in main.obj</p><p> Debug/迷宮問題.exe : fatal error LNK1169: one or mo
31、re multiply defined symbols found</p><p> 執(zhí)行 link.exe 時(shí)出錯(cuò).</p><p> 迷宮問題.exe - 1 error(s), 0 warning(s)</p><p><b> 改正:</b></p><p> 在main。cpp中原來包含的是stack.
32、cpp把它改為包含stack.h即可</p><p><b> 錯(cuò)誤二:</b></p><p> 用string直接定義字符串str時(shí),說沒有定義str</p><p> 原因:#include<string></p><p> using namespace std ;沒有用標(biāo)準(zhǔn)空間</p&
33、gt;<p><b> 錯(cuò)誤三:</b></p><p><b> 拼寫錯(cuò)誤</b></p><p><b> 正確結(jié)果輸出:</b></p><p><b> 接上面:</b></p><p><b> 接上面:<
34、/b></p><p><b> 5. 實(shí)驗(yàn)總結(jié)分析</b></p><p> 1)、時(shí)間和空間分析</p><p> 該算法的運(yùn)行時(shí)間和使用系統(tǒng)棧所占有的存儲(chǔ)空間與迷宮的大小成正比,迷宮長為m,寬為n,在最好情況下的時(shí)間和空間復(fù)雜度均為O(m+n),在最差情況下均為O(m*n),平均情況在它們之間</p><
35、p><b> 2)、程序的優(yōu)點(diǎn)</b></p><p> 進(jìn)入演示程序后即顯示文本方式的用戶界面</p><p> 本程序模塊劃分比較合理,且利用指針存儲(chǔ)迷宮,操作方便。</p><p> 能按照玩游戲人的意愿任意輸入迷宮大小,并且可以保存新輸入的迷宮,方便退出游戲后仍可打開自己定義文件查看迷宮。</p><p
36、> 3)、遇到的問題及如何解決</p><p> a.如何知道哪一點(diǎn)被探索過且路徑不通?</p><p> 答:maze【i】【j】本來時(shí)表示通與不通,那么可以當(dāng)探索該點(diǎn)之后,將其值賦為-1,就可以知道此點(diǎn)已經(jīng)被訪問過</p><p> b.如何正確的使用文件讀入迷宮?</p><p> 答:查看大一學(xué)的C++課本,仔細(xì)閱讀文
37、件那一章。</p><p> c.我想讓用戶在每次玩游戲之后都能查看輸入的迷宮,我想的是運(yùn)行程序時(shí)隨意新建文本文檔,開始是直接輸入一個(gè).txt結(jié)尾的字符串,但編譯好多錯(cuò)誤,我猜應(yīng)該是要調(diào)用相關(guān)函數(shù),但具體是那一個(gè)不清楚。 </p><p> 答:去圖書館借閱相關(guān)資料,要調(diào)用相應(yīng)的庫函數(shù)。</p><p> 4)、存在的缺陷、改進(jìn)設(shè)想</p>&l
38、t;p> 每當(dāng)自行輸入迷宮后,生成相應(yīng)的文件保存,但是我在想:一旦玩游戲的人多了,玩的次數(shù)多了,那么生成的保存迷宮文件就會(huì)很多,會(huì)給人工智能化系統(tǒng)造成文件冗余。我設(shè)想:能不能在一段時(shí)間之后系統(tǒng)自動(dòng)調(diào)用函數(shù)來清除冗余文件。</p><p> 5)、自我評價(jià)、經(jīng)驗(yàn)體會(huì)等</p><p> 通過這次課程設(shè)計(jì),體會(huì)如下:1、進(jìn)一步熟悉掌握了有關(guān)棧的基本操作;2、對迷宮有了更多的認(rèn)識(shí)
39、3、更進(jìn)一步掌握有關(guān)類的操作4、由于對棧的算法推敲不足,使程序調(diào)試時(shí)費(fèi)時(shí)不少</p><p> 總之:我認(rèn)為這次課程設(shè)計(jì)做的很好。課程設(shè)計(jì)的成功使我相信一句話:有付出就會(huì)有收獲,要相信自己。</p><p> 6. 附錄(源程序清單,要求含有至少30%的源碼附有注釋)</p><p> 迷宮程序代碼(本程序有個(gè)創(chuàng)新點(diǎn))</p><p&g
40、t; /////////////////////////////////////////////////////////////////////</p><p><b> /*</b></p><p> Name: stack.h </p><p> Author: 羅丹 </p><p> Descri
41、ption: 用于記錄探索路徑的棧類頭文件 </p><p><b> */</b></p><p> #include<iostream></p><p> #include"fstream"</p><p> using namespace std;</p>
42、<p> class DataType //定義描述迷宮中當(dāng)前位置的類型</p><p><b> {public:</b></p><p> int x; //x代表當(dāng)前位置的行坐標(biāo)</p><p> int y; //y代表當(dāng)前位置的列坐標(biāo)&
43、lt;/p><p> int pre; //pre表示移動(dòng)到下一步的方向</p><p> }; </p><p> class Move //定義下一個(gè)位置的方向</p><p><b> { public:</b></p>&l
44、t;p><b> int x; </b></p><p><b> int y;</b></p><p><b> };</b></p><p> class Node //鏈表結(jié)點(diǎn)</p><p><b> {publi
45、c:</b></p><p> DataType data;</p><p> Node *next;</p><p><b> };</b></p><p><b> //下面定義棧</b></p><p> class stack</p>
46、<p><b> {private:</b></p><p> Node *top; //指向第一個(gè)結(jié)點(diǎn)的棧頂指針</p><p><b> public:</b></p><p> stack(); //構(gòu)造函數(shù),置空棧</p>
47、<p> ~stack(); //析構(gòu)函數(shù)</p><p> void Push(DataType data);//把元素data壓入棧中</p><p> DataType Pop(); //使棧頂元素出棧</p><p> DataType GetPop(); //取出棧頂元素&l
48、t;/p><p> void Clear(); //把棧清空</p><p> bool IsEmpty(); //判斷棧是否為空,如果為空則返回1,否則返回0</p><p><b> };</b></p><p> /////////////////////////////
49、////////////////////////////////////////</p><p><b> /*</b></p><p> Name: stack.cpp </p><p> Author: 羅丹 </p><p> Description: 用于記錄探索路徑的棧類實(shí)現(xiàn)文件 </p&
50、gt;<p><b> */</b></p><p> #include"stack.h"</p><p> stack::stack() //構(gòu)造函數(shù),置空棧</p><p> {top=NULL;}</p><p> stack::
51、~stack() //析構(gòu)函數(shù)</p><p><b> {}</b></p><p> void stack::Push(DataType x) //進(jìn)棧</p><p> {Node *TempNode;</p><p> TempNode=new Nod
52、e;</p><p> TempNode->data=x;</p><p> TempNode->next=top;</p><p> top=TempNode;}</p><p> DataType stack::Pop() //棧頂元素出棧</p><p><b
53、> {</b></p><p> DataType Temp;</p><p> Node *TempNode=NULL;</p><p> TempNode=top;</p><p> top=top->next;</p><p> Temp=TempNode->data;&
54、lt;/p><p> delete TempNode;</p><p> return Temp;</p><p><b> }</b></p><p> DataType stack::GetPop() //取出棧頂元素</p><p> {return top-&
55、gt;data;}</p><p> void stack::Clear() //把棧清空</p><p> {top=NULL;}</p><p> bool stack::IsEmpty() //判斷棧是否為空,如果為空則返回1,否則返回0</p><p> {if(t
56、op==NULL) return true;</p><p> else return false;}</p><p> /////////////////////////////////////////////////////////////////////</p><p><b> /*</b></p><p>
57、; Name: main.cpp </p><p> Author: 羅丹 </p><p> Description: 主函數(shù)文件 </p><p><b> */</b></p><p> #include"stack.h"</p><p> #inc
58、lude<iostream></p><p> #include<string></p><p> #include<fstream></p><p> using namespace std ;</p><p><b> /*</b></p><p>
59、 Description: 外部函數(shù)的聲明部分</p><p><b> */</b></p><p> bool findpath(int **maze,int m,int n); //尋找迷宮路徑 </p><p> void PrintPath(stack p);
60、 //輸出路徑</p><p> void Restore(int **maze,int m,int n); //恢復(fù)迷宮</p><p> Move move[4]={{0,1},{1,0},{0,-1},{-1,0}}; //定義當(dāng)前位置移動(dòng)的4個(gè)方向(上,右,下,左)</p><p&g
61、t; int** readFile (int &m,int &n);</p><p> int** writeFile(int &m,int &n);</p><p><b> /*</b></p><p> Description: main.cpp</p><p><b
62、> */</b></p><p> void main()</p><p><b> { </b></p><p> cout<<endl;//</p><p> cout<<"◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆"<&
63、lt;endl;</p><p> cout<<" 2007-2008年度第一學(xué)期數(shù)據(jù)結(jié)構(gòu)課程之課程設(shè)計(jì) "<<endl;</p><p> cout<<endl;</p><p> cout<<"
64、 ——迷宮問題 "<<endl; </p><p> cout<<" 開發(fā)員 : 羅丹"<<endl;</p><p> cout<<" 專業(yè)班級: 計(jì)算機(jī)061班"<<endl;</p><p>
65、 cout<<"◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆"<<endl;</p><p> cout<<" 歡迎進(jìn)入迷宮游戲 "<<endl;</p><p> int m=0,n=0; </p>
66、<p> int **maze; </p><p><b> char ch;</b></p><p> int flag=0,flag1=0; </p><p> while(flag1==0)</p><p><b> {</b></p><p>
67、 while(flag==0)//標(biāo)志是否重新選擇</p><p> {cout<<endl;</p><p> cout<<" ★請從以下選項(xiàng)中選擇獲取迷宮的方法!"<<endl;</p><p> cout<<" <a>從文件中讀取"<
68、;<endl;</p><p> cout<<" <b>直接自行輸入"<<endl;</p><p> cout<<" ★請選擇:";</p><p><b> cin>>ch;</b></p><
69、p> if(ch=='a'){maze=readFile(m,n);flag=1;}</p><p> else if(ch=='b'){maze=writeFile(m,n);flag=1;}</p><p><b> else </b></p><p> cout<<"
70、★ Sorry!您輸入的選擇代碼不在范圍內(nèi)!請從新選擇"<<endl;</p><p><b> }</b></p><p> if(findpath(maze,m,n)) </p><p> cout<<" ★ Congratulations! 迷宮路徑探索成功!"<<
71、;endl; //得到路徑</p><p><b> else </b></p><p> cout<<" ★Sorry! 路徑不存在★"<<endl;</p><p> cout<<endl;</p><p> cout<<" ★
72、 繼續(xù)玩嗎?(y/n)"; </p><p><b> char c;</b></p><p><b> cin>>c;</b></p><p> if(c==n) flag1=1;</p><p> else flag=0;</p><p>
73、<b> }</b></p><p> cout<<"◆◆◆◆◆◆◆ 謝謝,您已經(jīng)退出迷宮系統(tǒng) ◆◆◆◆◆◆◆"<<endl;</p><p> cout<<"◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆"<<endl;</p><p>&
74、lt;b> }</b></p><p><b> /*</b></p><p> Description: 獲取迷宮函數(shù)</p><p><b> */</b></p><p> int** readFile (int &m,int &n)
75、 //讀出文件</p><p> {int **maze; </p><p> int i=0,j=0;</p><p> cout<<" ★您選擇的是直接從文件中讀取迷宮!"<<endl;</p><p> cout<<en
76、dl;</p><p> cout<<" 文件中的迷宮如下: "<<endl;</p><p> char ch; //定義一個(gè)字符,讀取文件中的內(nèi)容</p><p> ifstream open("maze.txt");
77、 //定義一個(gè)文件對象,并打開文件"maze.txt"</p><p> //讀取內(nèi)容記錄行數(shù)和列數(shù) (創(chuàng)新點(diǎn)一:從文件中直接讀取迷宮)</p><p> while(open.get(ch)) //從讀取文件中內(nèi)容(一旦個(gè)字符形式)</p><p> {if(ch=='0'
78、;||ch=='1') </p><p> {j++; } //是‘0’或‘1’字符寬就加1</p><p> if(ch=='\n') </p><p><b> {</b></p><p> i++
79、; //如果是換行符,就行加1</p><p> n=j; //得列數(shù)</p><p><b> j=0; </b></p><p><b> }</b
80、></p><p><b> }</b></p><p> open.close(); //讀取文件結(jié)束</p><p> m=i; </p><p> maze=new int *[m+2];
81、 //申請長度等于行數(shù)加2的二維指針(為后面的回復(fù)迷宮打下基礎(chǔ))</p><p> for(i= 0;i<m+2;i++) //申請空間</p><p> {maze[i]=new int[n+2];}</p><p><b> i=j=1;</
82、b></p><p> ifstream open1("maze.txt"); //重新讀取文件,以得到內(nèi)容</p><p> while(open1.get(ch))</p><p><b> {</b></p><p> if(ch==
83、9;1'||ch=='0')</p><p> {maze[i][j]=ch-'0'; //把數(shù)字字符轉(zhuǎn)化為數(shù)字,并存到指針里</p><p> cout<<maze[i][j]<<" "; //在屏
84、幕中顯示迷宮</p><p><b> j++;}</b></p><p> if(ch=='\n') //遇到換行,指針也相應(yīng)換行</p><p> {cout<<endl;</p><p><b> i
85、++;</b></p><p><b> j=1;}</b></p><p><b> }</b></p><p> open1.close(); //讀取結(jié)束</p><p> return maze; <
86、/p><p><b> }</b></p><p> int** writeFile (int &m,int &n) //將自定義迷宮寫入文件</p><p> {int a,b; </p><p><b> int i,j;</b><
87、;/p><p> int**maze;</p><p> cout<<" ★您選擇的是自行輸入迷宮!"<<endl;</p><p> cout<<" 請輸入迷宮的長:";cin>>b; //輸入迷宮的長和寬</p><p> cout
88、<<" 請輸入迷宮的寬:";cin>>a; </p><p> cout<<" ★請輸入迷宮內(nèi)容(0代表可通,1代表不通):\n";</p><p><b> m=a;</b></p><p> n=b;
89、 //m,n分別代表迷宮的行數(shù)和列數(shù)</p><p> maze=new int *[m+2]; </p><p> for(i= 0;i<m+2;i++) </p><p> {maze[i]=new int[n+2];} //創(chuàng)新點(diǎn)二::隨意申請空間</p><p> for
90、(i=1;i<=m;i++) //輸入迷宮的內(nèi)容,0代表可通,1代表不通</p><p> for(j=1;j<=n;j++)</p><p> cin>>maze[i][j];</p><p> cout<<" ★是否保存新迷宮?(y/n): ";</p&g
91、t;<p> char choose;</p><p> cin>>choose;</p><p> if(choose=='Y'||choose=='y')</p><p><b> {char ch;</b></p><p> string str;
92、</p><p> cout<<" ★請輸入保存迷宮的文件名(以.txt結(jié)束):";</p><p> cin>>str; </p><p> ofstream open(str.c_str()); //創(chuàng)新點(diǎn)三:按玩游戲人的意愿創(chuàng)建存儲(chǔ)迷宮的文件,也可不建立。</p><
93、p> for(i=1;i<=m;i++)</p><p> {for(j=1;j<=n;j++)</p><p> {ch='0'+maze[i][j];</p><p> open<<ch;}</p><p> open<<endl;</p><p>
94、; flush(cout);}</p><p> open.close();}</p><p> for(i=0;i<m+2;i++) </p><p> maze[i][0]=maze[i][n+1]=1;</p><p> for(i=0;i<n+2;i++)</p><
95、p> maze[0][i]=maze[m+1][i]=1;</p><p> return maze;</p><p><b> } </b></p><p><b> /*</b></p><p> Description: 探索路徑函數(shù)</p><p>
96、<b> */</b></p><p> bool findpath(int **maze,int m,int n)</p><p> {stack q,p; //創(chuàng)新點(diǎn)四:用棧p、q,分別存探索迷宮的過程和存儲(chǔ)路徑</p><p> DataType Temp1,Temp2;
97、</p><p> int x,y,loop;</p><p> Temp1.x=1;</p><p> Temp1.y=1;</p><p> q.Push(Temp1); //將入口位置入棧</p><p> p.Push(Temp1);
98、</p><p> maze[1][1]=-1; //創(chuàng)新點(diǎn)五:標(biāo)志入口位置已到達(dá)過</p><p> while(!q.IsEmpty()) //棧q非空,則反復(fù)探索</p><p> {Temp2=q.GetPop(); </p>
99、;<p> if(!(p.GetPop().x==q.GetPop().x&&p.GetPop().y==q.GetPop().y)) </p><p> p.Push(Temp2); </p><p> //如果有新位置入棧,則把上一個(gè)探索的位置存入棧p</p><p> for(loop=0;loop<
100、4;loop++) //探索當(dāng)前位置的4個(gè)相鄰位置</p><p> {x=Temp2.x+move[loop].x; </p><p> y=Temp2.y+move[loop].y; </p><p> if(maze[x][y]==0) //判
101、斷新位置是否可達(dá)</p><p> {Temp1.x=x;</p><p> Temp1.y=y;</p><p> maze[x][y]=-1; //標(biāo)志新位置已到達(dá)過</p><p> q.Push(Temp1); }
102、//新位置入棧</p><p> if((x==(m))&&(y==(n))) //成功到達(dá)出口</p><p> {Temp1.x=m;</p><p> Temp1.y=n;</p><p> Temp1.pre=0;</p><p> p.Pu
103、sh(Temp1); //把最后一個(gè)位置入棧</p><p> PrintPath(p); </p><p> Restore(maze,m,n); //恢復(fù)路徑(因?yàn)槊詫m里面的內(nèi)容已被改變</p><p> return 1; }}
104、 //表示成功找到路徑 </p><p> if(p.GetPop().x==q.GetPop().x&&p.GetPop().y==q.GetPop().y)//如果沒有新位置入棧,則返回到上一個(gè)位置 </p><p><b> {p.Pop();</b></p>
105、<p> q.Pop();}}</p><p> return 0; //表示查找失敗,即迷宮無路經(jīng)</p><p><b> }</b></p><p><b> /*</b></p><p> Descr
106、iption: 輸出路徑函數(shù)</p><p><b> */</b></p><p> void PrintPath(stack p) //輸出路徑</p><p> {cout<<endl;</p><p> cout<<" ★
107、★迷宮的路徑為"<<endl;</p><p> cout<<" 說明:括號內(nèi)的內(nèi)容分別表示為(行坐標(biāo),列坐標(biāo),方向)\n";</p><p> stack t; //定義一個(gè)棧,按從入口到出口存取路徑</p><p> int ro
108、w,column;</p><p> DataType data;</p><p> Node *temp;</p><p> temp=new Node; //申請空間</p><p> temp->data=p.Pop(); </p>&
109、lt;p> t.Push(temp->data); //第一個(gè)位置入棧</p><p> delete temp; </p><p> while(!p.IsEmpty()) //棧p非空,則轉(zhuǎn)移</p><p> {temp=ne
110、w Node;</p><p> temp->data=p.Pop(); //獲取下一個(gè)位置</p><p><b> //得到行走方向</b></p><p> row=t.GetPop().x-temp->data.x; //行坐標(biāo)方向</p
111、><p> column=t.GetPop().y-temp->data.y; //列坐標(biāo)方向</p><p> if(row==1) temp->data.pre=1; //向下,用1表示</p><p> else if(column==1) temp->data.pre=2;
112、//向右,用2表示</p><p> else if(row==-1) temp->data.pre=3; //向上,用3表示</p><p> else if(column==-1) temp->data.pre=4; //向左,用4表示</p><p> t.Push(temp->data);
113、 //把新位置入棧</p><p> delete temp;</p><p><b> }</b></p><p> while(!t.IsEmpty()) //棧非空,繼續(xù)輸出</p><p> {data=t.Pop();&l
114、t;/p><p> cout<<" "<<'('<<data.x<<','<<data.y<<","; </p><p> switch(data.pre) //輸出相應(yīng)的方向
115、 </p><p> {case 0:cout<<")\n";break;</p><p> case 1:cout<<"向下)\n";break;</p><p> case 2:cout<<"向右)\n";break;</p><p>
116、 case 3:cout<<"向上)\n";break;</p><p> case 4:cout<<"向左)\n";break;</p><p><b> }}}</b></p><p><b> /*</b></p><p>
117、 Description: 恢復(fù)路徑函數(shù)</p><p><b> */</b></p><p> void Restore(int **maze,int m,int n) //恢復(fù)迷宮</p><p><b> {int i,j;</b></p><p> for(i=0;
118、i<m+2;i++) //遍歷指針</p><p> for(j=0;j<n+2;j++) </p><p> {if(maze[i][j]==-1) //恢復(fù)探索過位置,即把-1恢復(fù)為0</p><p> maze[i][j]=0;}</p><p><b>
溫馨提示
- 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. 眾賞文庫僅提供信息存儲(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 迷宮問題課程設(shè)計(jì)報(bào)告
- 迷宮問題課程設(shè)計(jì)報(bào)告
- 迷宮問題課程設(shè)計(jì)報(bào)告
- 迷宮問題課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)迷宮問題課程設(shè)計(jì)報(bào)告
- 迷宮課程設(shè)計(jì)報(bào)告
- 迷宮課程設(shè)計(jì)報(bào)告
- 迷宮問題——數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告----迷宮問題
- c語言課程設(shè)計(jì)--迷宮問題
- 課程設(shè)計(jì)(迷宮)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)(迷宮問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)—迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)迷宮問題課程設(shè)計(jì)
評論
0/150
提交評論