版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p> 存檔資料 成績: </p><p> 課 程 設(shè) 計 報 告 書</p><p> 所屬課程名稱 數(shù)據(jù)結(jié)構(gòu) </p><p> 題 目 騎士游歷 </p><p> 分 院
2、 電信分院 </p><p> 專業(yè)班級 </p><p> 學(xué) 號 </p><p> 學(xué)生姓名 &
3、lt;/p><p> 指導(dǎo)教師 </p><p> 2013 年 7月 5 日 </p><p><b> 目 錄</b></p><p> 第一章 課程設(shè)計內(nèi)容及要求2</p><p> 第二章 課程設(shè)計的設(shè)計分析
4、與功能模塊1</p><p> 2.1 設(shè)計分析1</p><p><b> (1)設(shè)計目的1</b></p><p><b> (2)任務(wù)分析1</b></p><p><b> 1. 要求1</b></p><p><b&g
5、t; 2. 輸入1</b></p><p> 2.2 程序功能模塊圖1</p><p> 第三章 流程圖設(shè)計的具體實現(xiàn)3</p><p> 3.1 馬踏遍棋盤流程圖3</p><p> 3.2 系統(tǒng)測試與調(diào)試5</p><p> 第四章 源代碼程序設(shè)計9</p&g
6、t;<p> 4.1 詳細設(shè)計9</p><p><b> 創(chuàng)建9</b></p><p><b> 操作9</b></p><p><b> 顯示9</b></p><p> 4.2 源代碼10</p><p>
7、 第五章 課程設(shè)計心得13</p><p> 第六章 參考文獻14</p><p> 第七章 致謝15</p><p> 第一章 課程設(shè)計內(nèi)容及要求</p><p> 騎士游歷問題是一個古老而著名的問題,問題的描述是:在8×8格的國際象棋棋盤上,象棋馬能否從某個格子出發(fā)按照“馬跳
8、日”的規(guī)則跳遍所有64個格子最后 再回到出發(fā)的那個格子。國際象棋中的馬,英語為knight,恰好又意指中世紀西方世界的“騎士”,因此,這個問題又被稱為“騎士游歷。</p><p> 在一個棋盤上(8行8列)放一個“馬”,按“馬走日字”的規(guī)則,馬要走到棋盤上每一個格子,且每個格子只走一次。</p><p> 用回溯法深度優(yōu)先搜索,若尋找到滿足要求的解,則輸出;否則推回上一層往下一個方向搜
9、索。</p><p> 對于當(dāng)前所在位置(x,y),依次枚舉8個方向搜索,直到找到一組可行解為止。使用剪枝有2處:</p><p> 第一、使用Warnsdorff's rule,枚舉當(dāng)前解得時候優(yōu)先選擇下一步可行步數(shù)最少的方向;</p><p> 第二、若第一點中的方向存在不止一個,則優(yōu)先選擇離中心位置較遠的方向;每次都從中心點開始出發(fā),求出一條合法
10、路徑后再平移映射回待求路徑。</p><p> 第二章 課程設(shè)計的設(shè)計分析與功能模塊</p><p><b> 2.1 設(shè)計分析</b></p><p><b> (1)設(shè)計目的</b></p><p> 1.熟練使用C語言編寫程序,強化模塊設(shè)計理念。</p><
11、p> 2.設(shè)計一個國際象棋馬踏棋盤的演示程序。</p><p> 3.理解棧的特性“后進先出” 和隊列的特性“先進先出”。</p><p> 4.初步掌握軟件開發(fā)過程的問題分析、系統(tǒng)設(shè)計、程序編 碼、測試等基本方法和技能。</p><p><b> (2)任務(wù)分析</b></p><p><b>
12、 1. 要求</b></p><p> 在國際象棋8×8棋盤上面,按照國際象棋規(guī)則中馬的行進規(guī)則,實現(xiàn)從任意初始位置,每個方格只進入一次,走遍棋盤上全部64個方格。編制程序,求出馬的行走路線,并按求出的行走路線,將數(shù)字1,2,…,64依次填入一個8×8的方陣,并輸出它的行走路線。</p><p><b> 2. 輸入</b><
13、;/p><p> 任意一個起始位置;輸出:無重復(fù)踏遍棋盤的結(jié)果,以數(shù)字1-64表示行走路線。</p><p> 2.2 程序功能模塊圖</p><p> 各模塊之間的調(diào)用關(guān)系,如圖所示:</p><p> 第三章 流程圖設(shè)計的具體實現(xiàn)</p><p> 3.1 馬踏遍棋盤流程圖</p><
14、;p> 3.2 系統(tǒng)測試與調(diào)試</p><p> 1.程序代碼的輸入和運行</p><p> 新建C文件并輸入代碼到工作界面當(dāng)中,仔細檢查,運行代碼,如下圖所示,圖3.2-1表示程序的輸入和運行,</p><p><b> 圖3.2—1</b></p><p><b> 圖3.2—2</b
15、></p><p><b> 2.程序代碼的調(diào)試</b></p><p> 經(jīng)過請教老師和同學(xué)們的幫助,還有自己的多次調(diào)試,終于修改好了程序代碼,運行后準確無誤,如圖3.2-3所示:</p><p><b> 圖3.2-3</b></p><p><b> 3 程序的顯示結(jié)果
16、</b></p><p> 在命令窗口中輸入了棋子的不同起點,運行都成功了。如下圖所示:</p><p> 圖3.2-4 以(1,1)為起點</p><p> 圖3.2-5 以(0,5)為起點</p><p> 圖3.2-6 以(2,0)為起點</p><p> 圖3.2-6 以(4,0)為起點&
17、lt;/p><p> 圖3.2-6 以(0,3)為起點</p><p> 第四章 源代碼程序設(shè)計</p><p><b> 4.1 詳細設(shè)計</b></p><p><b> 創(chuàng)建</b></p><p> 創(chuàng)建一個8行8列的棋盤:</p>&l
18、t;p> #include <stdio.h></p><p> int board[8][8] = {0};</p><p> int main(void) {</p><p> for(i = 0; i < 8; i++) {</p><p> for(j = 0; j < 8; j++) {<
19、;/p><p> printf("%2d ", board[i][j]);</p><p><b> }</b></p><p> putchar('\n');</p><p><b> }</b></p><p><b>
20、 return 0;</b></p><p><b> }</b></p><p><b> 操作</b></p><p> 輸入騎士的初始位置,進行騎士游歷操作:</p><p><b> int i, j;</b></p><p>
21、; printf("輸入起始點:");</p><p> int travel(int x, int y) {</p><p> int ktmove1[8] = {-2, -1, 1, 2, 2, 1, -1, -2};</p><p> int ktmove2[8] = {1, 2, 2, 1, -1, -2, -2, -1};<
22、;/p><p><b> 顯示</b></p><p><b> 顯示出游歷結(jié)果:</b></p><p> int startx, starty;</p><p><b> int i, j;</b></p><p> printf("
23、輸入起始點:");</p><p> scanf("%d %d", &startx, &starty);</p><p> if(travel(startx, starty)) {</p><p> printf("游歷完成!\n");</p><p><b>
24、 }</b></p><p><b> else {</b></p><p> printf("游歷失?。n");</p><p><b> }</b></p><p><b> 4.2 源代碼</b></p><
25、;p> #include <stdio.h> </p><p> #define N 5</p><p> #define NSQUARE N*N </p><p> int HorseTry(int i, int x, int y, int h[N+1][N+1]); </p><p> static int a
26、[9] = {0, 2, 1, -1, -2, -2, -1, 1, 2};</p><p> static int b[9] = {0, 1, 2, 2, 1, -1, -2, -2, -1}; </p><p><b> main()</b></p><p><b> {</b></p><p
27、> int i, j, flag, x, y;</p><p> static int h[N+1][N+1] ={0}; </p><p> printf("Input the initial position x,y:");</p><p> scanf("%d,%d", &x, &y);&l
28、t;/p><p> h[x][y] = 1;</p><p> flag = HorseTry(2, x, y, h);</p><p><b> if (flag)</b></p><p><b> {</b></p><p> printf("Output
29、:\n");</p><p> for (i=1; i<=N; i++)</p><p><b> {</b></p><p> for (j=1; j<=N; j++)</p><p><b> {</b></p><p> printf(&
30、quot;%5d", h[i][j]);</p><p><b> }</b></p><p> printf("\n");</p><p><b> }</b></p><p><b> }</b></p><p>
31、;<b> else</b></p><p><b> {</b></p><p> printf("No solution!\n");</p><p><b> }</b></p><p><b> } </b></p
32、><p> int HorseTry(int i, int x, int y, int h[N+1][N+1])</p><p><b> {</b></p><p> int u, v, flag, count = 0;</p><p><b> do{</b></p><
33、p><b> count++;</b></p><p><b> flag = 0;</b></p><p> u = x + a[count];</p><p> v = y + b[count];</p><p> if ((u>=1&&u<=N) &
34、amp;& (v>=1&&v<=N) && h[u][v]==0)</p><p><b> {</b></p><p> h[u][v] = i;</p><p> if (i < NSQUARE)</p><p><b> {</b&g
35、t;</p><p> flag = HorseTry(i+1, u, v, h);</p><p> if (!flag) h[u][v] = 0;</p><p><b> }</b></p><p><b> else</b></p><p><b>
36、 {</b></p><p><b> flag = 1;</b></p><p><b> }</b></p><p><b> }</b></p><p> }while (!flag && count<8);</p>
37、<p> return flag;</p><p><b> }</b></p><p> 第五章 課程設(shè)計心得</p><p> 通過兩個星期對騎士游歷這個程序的分析,我對C語言這門課程有了進一步的鞏固,對我們現(xiàn)在學(xué)的《數(shù)據(jù)結(jié)構(gòu)(C語言版)》的知識有了一個很好的回顧和掌握,我的在這個過程中我也知道自己能力的不足
38、,在面對問題的時候更應(yīng)該要請教老師和同學(xué),自己也可以動手查閱資料。我們不單是要提高自己的理論能力,還要多去實踐,這樣我們就能夠更好的提高自己。</p><p> 課程設(shè)計是我們專業(yè)課程知識綜合應(yīng)用的實踐訓(xùn)練,是我們邁向社會,從事職業(yè)工作前一個必不少的過程.”千里之行始于足下”,通過這次課程設(shè)計,我深深體會到這句千古名言的真正含義.我今天認真的進行課程設(shè)計,學(xué)會腳踏實地邁開這一步,就是為明天能穩(wěn)健地在社會大潮中奔
39、跑打下堅實的基礎(chǔ).</p><p> 在這次設(shè)計過程中,體現(xiàn)出自己單獨設(shè)計的能力以及綜合運用知識的能力,體會了學(xué)以致用、突出自己勞動成果的喜悅心情,從中發(fā)現(xiàn)自己平時學(xué)習(xí)的不足和薄弱環(huán)節(jié),從而加以彌補。</p><p> 第六章 參考文獻</p><p> [1] 謝希仁. 計算機網(wǎng)絡(luò)(第五版)[M]. 北京:電子工業(yè)出版社,2008年2月&l
40、t;/p><p> [2] 胡小強 計算機網(wǎng)絡(luò)[M] 北京:北京郵電大學(xué)出版社2005 年1月</p><p> [3] 嚴蔚敏 李冬梅 吳偉民 數(shù)據(jù)結(jié)構(gòu)(C語言版)[M] 人民郵電出版社,2011年2月</p><p> [4] 李麗娟 C語言程序設(shè)計教程(第二版)[M] 北京:人民郵電出版社2009年3月</p><p>
41、[5] 朱戰(zhàn)立.《數(shù)據(jù)結(jié)構(gòu)(C++語言描述)》(第二版本).高等教育出版社。</p><p> [6] 陸蓓. C語言程序設(shè)計(第二版)[M]. 北京:科學(xué)出版社,2009</p><p> [7] 嚴蔚敏. 數(shù)據(jù)結(jié)構(gòu):C語言版[M]. 北京:清華大學(xué)出版社,2007.</p><p> 第七章 致謝 </p>&l
42、t;p> 感謝學(xué)院領(lǐng)導(dǎo)與分院領(lǐng)導(dǎo)的大力支持,感謝指導(dǎo)老師的</p><p> 辛勤指導(dǎo),感謝同學(xué)們的熱心幫助,感謝室友的無私幫助。</p><p> 在此感謝我們的指導(dǎo)老師,老師嚴謹細致、一絲不茍的作風(fēng)一直是我工作、學(xué)習(xí)中的榜樣;老師循循善誘的教導(dǎo)和不拘一格的思路給予我無盡的啟迪;這次課程設(shè)計的每個細節(jié)和每個數(shù)據(jù),都離不開老師您的細心指導(dǎo)。而您開朗的個性和寬容的態(tài)度,幫助我能夠
溫馨提示
- 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)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計--騎士游歷
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計----huffman編碼
- java課程設(shè)計--騎士游歷程序的開發(fā)
- 數(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è)計
- 數(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)的實現(xiàn)
- 數(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
提交評論