版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p> 《C++程序》迷宮游戲設(shè)計(jì)報(bào)告</p><p> 專 業(yè): 電子信息工程 </p><p> 班 級: 2班 </p><p> 姓 名: </p><p> 學(xué) 號: 2011508
2、217 </p><p> 目 錄</p><p> 1、課程設(shè)計(jì)的目的、課程設(shè)計(jì)題目、題目要求3</p><p> 1.1課程設(shè)計(jì)的目的3</p><p> 1.2課程設(shè)計(jì)的題目3</p><p><b> 1.3題目要求3</b></p&
3、gt;<p> 2課程設(shè)計(jì)的實(shí)驗(yàn)報(bào)告內(nèi)容:4</p><p> 3課程設(shè)計(jì)的原程序代碼:4</p><p><b> 4運(yùn)行結(jié)果16</b></p><p> 5課程設(shè)計(jì)總結(jié)20</p><p><b> 6參考書目21</b></p><p&g
4、t;<b> 1課程設(shè)計(jì)的目的</b></p><p> 1.1課程設(shè)計(jì)的目的:</p><p> 為大家解決一些生活中實(shí)際的問題,在這個(gè)過程中,自身的能力也在不斷地提高。此次 程序設(shè)計(jì)綜合運(yùn)用所學(xué)知識解決實(shí)際問題, 將課堂的書本知識有效的在程序中體現(xiàn)出來, 讓 學(xué)生更理解 C++功能之強(qiáng)大,進(jìn)一步讓學(xué)生對面向?qū)ο蟮姆椒ㄒ约?C++的編程思想有較好的了解和認(rèn)識。
5、此外,此次設(shè)計(jì)培養(yǎng)獨(dú)立開發(fā)、設(shè)計(jì)、調(diào)試、運(yùn)行程序的能力,激發(fā)學(xué)生較 強(qiáng)的自學(xué)興趣,鍛煉學(xué)生之間以及學(xué)生與老師的溝通能力,培養(yǎng)學(xué)生之間的合作精神,讓彼 此更好的認(rèn)識到合作的重要性,使學(xué)生在今后的學(xué)習(xí)中加強(qiáng)對合作精神的培養(yǎng)。</p><p> 1.2課程設(shè)計(jì)的題目: 迷宮游戲設(shè)計(jì)</p><p><b> 1.3題目要求:</b></p><p&g
6、t; 編一迷宮游戲程序,迷宮生成有用戶輸入和程序自動生成兩種方式(迷宮以矩陣表示),要求輸出迷宮和走出迷宮的路徑。</p><p> 2課程設(shè)計(jì)的實(shí)驗(yàn)報(bào)告內(nèi)容:</p><p> ?。?)迷宮數(shù)組定義為結(jié)構(gòu)體包含兩個(gè)整型數(shù)據(jù),迷宮出口和入口的值定義為整型。 (2)迷宮內(nèi)部的設(shè)計(jì)時(shí)各坐標(biāo)點(diǎn)設(shè)置成棧內(nèi)整型。 (3)迷宮中求最短路徑時(shí)定義結(jié)構(gòu)體類型表示隊(duì)列,包含整型坐標(biāo)點(diǎn),和整型下標(biāo); 又有
7、整型的隊(duì)首尾指針。</p><p> 3課程設(shè)計(jì)的原程序代碼:</p><p> #include<iostream></p><p> #include<stack></p><p> #include<stdio.h></p><p> #include<time
8、.h></p><p> #include<string></p><p> using namespace std;</p><p> typedef struct</p><p><b> {</b></p><p><b> int x,y;</b
9、></p><p><b> }item;</b></p><p> typedef struct</p><p><b> {</b></p><p> int x,y,d;</p><p> }Datetype;</p><p>
10、 typedef stack<Datetype> stack_int;</p><p> void path (int **maze,int,int,int,int);</p><p> void printpath();</p><p> #define NUM 100 //隊(duì)列大小;</p><p> typed
11、ef struct{</p><p> int x,y; //所到點(diǎn)的坐標(biāo);</p><p> int pre; //前驅(qū)點(diǎn)的下標(biāo);</p><p> }SqType; //隊(duì)列;</p><p> int front,rear; //隊(duì)首指針與隊(duì)尾指針;</p><p> void printpat
12、h(SqType sq[],int){//打印路徑</p><p><b> int i;</b></p><p><b> i=rear; </b></p><p><b> do{</b></p><p> cout<<"("<
13、<sq[i].x<<","<<sq[i].y<<")<--";</p><p> i=sq[i].pre; //回溯;</p><p> }while(i!=-1);</p><p><b> }</b></p><p>
14、 void restore(int **maze,int m,int n){//恢復(fù)迷宮</p><p> for(int i=1;i<=m;i++){</p><p> for(int j=1;j<=n;j++){</p><p> if(maze[i][j]==-1)</p><p> maze[i][j]=0;<
15、;/p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> int path1(int **maze,int m,int n,int c,int d,int x1,int y1)//最短路徑</p
16、><p> { //m,n為迷宮的長和寬,c,d為迷宮入口坐標(biāo),x1,y1為迷宮出口坐標(biāo);maze為迷宮;</p><p> item move[8]={{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1},{-1,0},{-1,1}}; //坐標(biāo)增量數(shù)組;</p><p> SqType sq[NUM];</p>&l
17、t;p> int x,y,i,j,v; </p><p> front=rear=0;</p><p> sq[0].x=c;</p><p> sq[0].y=d;</p><p> sq[0].pre=-1; </p><p> if(maze[c][d]==0)</p><
18、p> maze[c][d]=-1;//入口點(diǎn)入隊(duì);</p><p> else goto G;</p><p> while(front<=rear){ //隊(duì)列不為空</p><p> x=sq[front].x;</p><p> y=sq[front].y;</p><p> fo
19、r(v=0;v<8;v++){</p><p> i=x+move[v].x;</p><p> j=y+move[v].y;</p><p> if(maze[i][j]==0){</p><p><b> rear++;</b></p><p> sq[rear].x=i;&l
20、t;/p><p> sq[rear].y=j;</p><p> sq[rear].pre=front;</p><p> maze[i][j]=-1; //訪問過的坐標(biāo)點(diǎn),入隊(duì);</p><p><b> }</b></p><p> if(i==x1&&j==y1){&l
21、t;/p><p> cout<<"最短路徑為:"<<endl;</p><p> printpath(sq,rear); //輸出路徑;</p><p> restore(maze,m,n); //恢復(fù)迷宮;</p><p> return 1; </p><p>
22、;<b> }</b></p><p> } //for v;</p><p> front++; //當(dāng)前點(diǎn)搜索完,取下一個(gè)點(diǎn)搜索</p><p> } //while</p><p> G:cout<<"無路徑。"<<endl;</p>
23、<p><b> return 0;</b></p><p><b> }</b></p><p> void path(int **maze,int a,int b,int m,int n)</p><p><b> {</b></p><p> item
24、 move[8]={{0,1},{1,1},{1,0},{1,-1},{0,-1},{-1,-1},{-1,0},{-1,1}};</p><p> stack_int st;</p><p> Datetype temp;</p><p> int x,y,d,i,j;</p><p> if(maze[a][b]==1){cout
25、<<"進(jìn)口輸入有誤。";return;}</p><p> temp.x=a;temp.y=b;temp.d=-1; //初始化入口點(diǎn)坐標(biāo)及方向;</p><p> st.push(temp);</p><p> while(!st.empty())</p><p><b> {</b&
26、gt;</p><p> temp=st.top();</p><p><b> st.pop();</b></p><p> x=temp.x;y=temp.y;d=temp.d+1;</p><p> while(d<8)</p><p><b> {</b&g
27、t;</p><p> i=x+move[d].x;j=y+move[d].y;</p><p> if(maze[i][j]==0) //該點(diǎn)可到達(dá);</p><p><b> {</b></p><p> temp.x=x;temp.y=y;temp.d=d; //坐標(biāo)及方向;</p><
28、;p> st.push(temp); //坐標(biāo)及方向入棧;</p><p><b> x=i;y=j;</b></p><p> maze[x][y]=-1;//到達(dá)新點(diǎn);</p><p> if(x==m && y==n)</p><p><b> {</b><
29、;/p><p> cout<<" 迷宮路徑為:"<<endl;</p><p> cout<<"("<<m<<","<<n<<")<---";</p><p> Datetype t;</p
30、><p> while(!st.empty())</p><p><b> {</b></p><p> t=st.top();</p><p> cout<<"("<<t.x<<","<<t.y<<")&l
31、t;---";</p><p><b> st.pop();</b></p><p> } //輸出路徑;</p><p> cout<<endl;</p><p> return ; //到達(dá)出口;</p><p><b> }</b>
32、;</p><p> else d=0; //重新初始化方向;</p><p><b> }</b></p><p> else d++; //改變方向;</p><p><b> }</b></p><p><b> }</b>&l
33、t;/p><p> cout<<"對不起,無法找到出口.";</p><p> return; //迷宮無路;</p><p><b> }</b></p><p> void printpath()</p><p><b> {</b&g
34、t;</p><p> int m,n,i,j,l,c,d;</p><p><b> string s;</b></p><p> cout<<" 請輸入迷宮的行數(shù)列數(shù)如:(m n)"<<endl;</p><p> cin>>m>>n;<
35、;/p><p> int **maze=new int*[m+2];</p><p> for(i=0;i<=m+1;i++)</p><p> maze[i]=new int[n+2];//申請迷宮的空間;</p><p> for(i=0;i<=m+1;i++) </p><p> maze[
36、i][0]=1;</p><p> for(i=0;i<=n+1;i++)</p><p> maze[0][i]=1;</p><p> for(i=0;i<=m+1;i++)</p><p> maze[i][n+1]=1;</p><p> for(i=0;i<=n+1;i++)<
37、;/p><p> maze[m+1][i]=1; //建立迷宮周圍的墻;</p><p> cout<<"1、采用創(chuàng)建好的迷宮; 2、自己創(chuàng)建迷宮(其他輸入按'2'處理)"<<endl;</p><p><b> cin>>s;</b></p><p
38、> if(s=="1")</p><p><b> {</b></p><p> srand(time(0)); //系統(tǒng)時(shí)間隨機(jī)函數(shù);</p><p> for(i=1;i<=m;i++)</p><p> for(j=1;j<=n;j++)</p>&l
39、t;p> maze[i][j]=rand()%2; //隨機(jī)賦值</p><p> maze[1][1]=0; //(1,1)點(diǎn)為可通過點(diǎn);</p><p> maze[m][n]=0; //(m,n)點(diǎn)為可通過點(diǎn);</p><p><b> }</b></p><p><b> el
40、se </b></p><p><b> {</b></p><p> cout<<"請輸入迷宮:"<<m<<"行"<<n<<"列"<<", 輸入必須為'0' 或 '1';&quo
41、t;<<endl;</p><p> for(i=1;i<=m;i++) //輸入第i行迷宮的構(gòu)造;</p><p> for(j=1;j<=n;j++) //輸入第j列迷宮的結(jié)構(gòu);</p><p><b> {</b></p><p> cin>>maze[i
42、][j];</p><p> A:if(maze[i][j]!=0 && maze[i][j]!=1)</p><p><b> {</b></p><p> cout<<"請?jiān)俅屋斎耄?quot;;</p><p> cin>>maze[i][j];goto A
43、; //判錯(cuò);</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> cout<<"迷宮如下:"<<endl; //顯示用戶輸入的迷宮;<
44、/p><p> for(i=0;i<=m+1;i++)</p><p><b> {</b></p><p> for(j=0;j<=n+1;j++)</p><p> cout<<maze[i][j]<<" ";</p><p> c
45、out<<endl;</p><p><b> }</b></p><p> H:cout<<"請輸入迷宮入口(a,b),出口(c,d):";</p><p> cin>>i>>j>>c>>d;</p><p> path
46、(maze,i,j,c,d); //調(diào)用路徑函數(shù),輸出路徑;</p><p> cout<<endl; //格式設(shè)置;</p><p> restore(maze,m,n); //恢復(fù)迷宮;</p><p> path1(maze,m,n,i,j,c,d); //輸出最短路徑;</p><p> cout&l
47、t;<endl; //格式設(shè)置;</p><p> cout<<"1、尋找其他入口與出口;2、退出此迷宮;";</p><p><b> cin>>l; </b></p><p><b> if(l==1){</b></p><p> r
48、estore(maze,m,n); //恢復(fù)迷宮;</p><p><b> goto H;</b></p><p><b> }</b></p><p> else return; //跳出此函數(shù);</p><p><b> }</b></p>&
49、lt;p> void main()</p><p><b> {</b></p><p> string s="Y";</p><p><b> do</b></p><p><b> {</b></p><p>
50、cout<<"--------------------------歡迎到達(dá)迷宮界面--------------------------\n";</p><p> printpath();</p><p> cout<<endl;</p><p> cout<<"\n 是否繼續(xù)?'Y
51、9; 或'N'(輸入其他操作按'N')"<<endl;</p><p><b> cin>>s;</b></p><p> }while (s=="Y"||s=="y");</p><p> system("pause&qu
52、ot;);</p><p><b> }</b></p><p><b> 4運(yùn)行結(jié)果:</b></p><p><b> 5. 課程設(shè)計(jì)總結(jié)</b></p><p> 為大家解決一些生活中實(shí)際的問題,在這個(gè)過程中,自身的能力也在不斷地提高。此次 程序設(shè)計(jì)綜合運(yùn)用所學(xué)知
53、識解決實(shí)際問題, 將課堂的書本知識有效的在程序中體現(xiàn)出來, 讓 學(xué)生更理解 C++功能之強(qiáng)大,進(jìn)一步讓學(xué)生對面向?qū)ο蟮姆椒ㄒ约?C++的編程思想有較好的了解和認(rèn)識。此外,此次設(shè)計(jì)培養(yǎng)獨(dú)立開發(fā)、設(shè)計(jì)、調(diào)試、運(yùn)行程序的能力,激發(fā)學(xué)生較 強(qiáng)的自學(xué)興趣,鍛煉學(xué)生之間以及學(xué)生與老師的溝通能力,培養(yǎng)學(xué)生之間的合作精神,讓彼 此更好的認(rèn)識到合作的重要性,使學(xué)生在今后的學(xué)習(xí)中加強(qiáng)對合作精神的培養(yǎng)。一般來說,課程設(shè)計(jì)要比教學(xué)實(shí)驗(yàn)復(fù)雜一些,涉及的深度深,而
54、且更加實(shí)用些。其目的 是通過課程設(shè)計(jì)的綜合訓(xùn)練, 培養(yǎng)學(xué)生分析解決實(shí)際問題和編程等動手能力, 最終目標(biāo)是想 通過這種形式,幫助學(xué)生系統(tǒng)掌握 C++這門課程的主要內(nèi)容,使老師更好的完成教學(xué)任務(wù)。 結(jié)合實(shí)際應(yīng)用的要求, 使課程設(shè)計(jì)既覆蓋教學(xué)所要求的知識點(diǎn), 又接近工程的實(shí)際需要, 訓(xùn)練自己實(shí)際分析問題和解決問題以及編程的能力。 通過詳細(xì)的實(shí)例分析,循環(huán)漸進(jìn)的描述,啟發(fā)學(xué)生順利的完成設(shè)計(jì)。課程設(shè)計(jì)將設(shè)計(jì)要 求、需求分析、算法設(shè)計(jì)、編程和實(shí)例測
溫馨提示
- 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)方式做保護(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ì)報(bào)告
- 迷宮問題課程設(shè)計(jì)報(bào)告
- 課程設(shè)計(jì)(迷宮)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)迷宮問題課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--迷宮
- 課程設(shè)計(jì)迷宮求解
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---迷宮求解
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告迷宮求解
- 數(shù)據(jù)結(jié)構(gòu)迷宮求解課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告----迷宮問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---迷宮算法
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告-迷宮求解
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---迷宮問題
- 高級語言課程設(shè)計(jì)——迷宮實(shí)驗(yàn)報(bào)告
- 羅密歐與朱麗葉迷宮課程設(shè)計(jì)報(bào)告
- c語言課程設(shè)計(jì)--迷宮
評論
0/150
提交評論