版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計</b></p><p><b> 選題: 八皇后問題</b></p><p><b> 姓 名:</b></p><p><b> 學(xué) 號:</b></p><p><b> 指
2、導(dǎo)老師: </b></p><p> 目 錄一.選題概述---------------------------------------3</p><p> 設(shè)計要求與分析--------------------------------3</p><p> 數(shù)據(jù)結(jié)構(gòu)與定義--------------------------
3、------4</p><p><b> 1.結(jié)構(gòu)體定義</b></p><p><b> 2.函數(shù)定義</b></p><p><b> 3.函數(shù)之間的定義</b></p><p> 程序段與分析----------------------------------5&
4、lt;/p><p> 完整程序代碼及運行結(jié)果截圖------------------7</p><p> 心得體會--------------------------------------10</p><p> 參考文獻--------------------------------------10</p><p><b>
5、一.選題概述:</b></p><p> 在實際應(yīng)用中,有相當(dāng)一類問題需要找出它的解集合,或者要求找出某些約束條件下的最優(yōu)解。求解時經(jīng)常使用一種稱為回溯的方法來解決。所謂回溯就是走回頭路,該方法是在一定的約束條件下試探地搜索前進,若前進中受阻,則回頭另擇通路繼續(xù)搜索。為了能夠沿著原路逆序回退,需用棧來保存曾經(jīng)到達的每一個狀態(tài),棧頂?shù)臓顟B(tài)即為回退的第一站,因此回溯法均可利用棧來實現(xiàn)。而解決八皇后問題就
6、是利用回溯法和棧來實現(xiàn)的。</p><p><b> 二.設(shè)計要求與分析</b></p><p> 八皇后問題是在8x8的國際象棋棋盤上,安放8個皇后,要求沒有一個皇后能夠“吃掉”任何其他一個皇后,即沒有兩個或兩個以上的皇后占據(jù)棋盤上的同一行、同一列或同一條對角線。</p><p> 八皇后在棋盤上分布的各種可能的格局,其數(shù)目非常大,約等
7、于232種,但是,可以將一些明顯不滿足問題要求的格局排除掉。由于任意兩個皇后不能同行,即每一行只能放置一個皇后,因此將第i個皇后放置在第i行上。這樣在放置第i個皇后時,只要考慮它與前i一1個皇后處于不同列和不同對角線位置上即可。因此,其算法基本思想如下:</p><p> 從第1行起逐行放置皇后,每放置一個皇后均需要依次對第1,2,…,8列進行試探,并盡可能取小的列數(shù)。若當(dāng)前試探的列位置是安全的,即不與已放置的
8、其他皇后沖突,則將該行的列位置保存在棧中,然后繼續(xù)在下一行上尋找安全位置;若當(dāng)前試探的列位置不安全,則用下一列進行試探,當(dāng)8列位置試探完畢都未找到安全位置時,就退棧回溯到上一行,修改棧頂保存的皇后位置,然后繼續(xù)試探。</p><p> 該算法抽象描述如下:</p><p> ?。?)置當(dāng)前行當(dāng)前列均為1;</p><p> (2)while(當(dāng)前行號《8)<
9、;/p><p> ?。?){檢查當(dāng)前行,從當(dāng)前列起逐列試探,尋找安全列號;</p><p> ?。?)if(找到安全列號)</p><p> ?。?)放置皇后,將列號記入棧中,并將下一行置成當(dāng)前行,第1列置為當(dāng)前列;</p><p><b> ?。?)else</b></p><p> (7)退?;?/p>
10、溯到上一行,移去該行已放置的皇后,以該皇后所在列的下一列作為</p><p><b> 當(dāng)前列;</b></p><p><b> ?。?)}結(jié)束程序。</b></p><p><b> 數(shù)據(jù)結(jié)構(gòu)與定義</b></p><p><b> 結(jié)構(gòu)體定義</b&
11、gt;</p><p> typedef struct</p><p><b> {</b></p><p> int col[MaxSize]; //col[i]存放第i個皇后的列號</p><p> int top; //棧頂指針</p><p><b> }Typ
12、e;</b></p><p><b> 2.函數(shù)定義</b></p><p> bool place(Type st,int i,int j) //測試(i,j)是否與1~i-1皇后有沖突 </p><p> void queen(int n) //求解皇后問題</p><p> void ma
13、in() //主函數(shù)</p><p><b> 函數(shù)之間的調(diào)用關(guān)系</b></p><p> main queen place</p><p><b> 程序塊與分析</b></p><p> bool place(Type st,int i,int j)//測試
14、(i,j)是否與1~i-1皇后有沖突</p><p><b> {</b></p><p><b> int k=1;</b></p><p> if(i==1) return true;//存放第一個皇后時沒有沖突</p><p> while(k<=i-1)//j=1到k-1是已經(jīng)
15、放置了皇后的列</p><p><b> {</b></p><p> if((st.col[k]==j)||(abs(j-st.col[k])==abs(k-i)))</p><p> return false;</p><p><b> k++;</b></p><p
16、><b> }</b></p><p> return true;</p><p><b> }</b></p><p> ?。╧,st.col[k]) (k,st.col[k])</p><p> j-st.col[k]
17、 j-st.col[k] </p><p> (i,j) i-k i-k (i,j)</p><p> //測試(i,j)位置是否與已經(jīng)放好的第1個到第i~1皇后有沖突。已經(jīng)放置好的第1個到第1~i-1個皇后已放置在st棧中。St棧用
18、的是順序棧,棧頂指針從1開始,st.col[k]用于存放第k(1<=i<=k-1)個皇后的列號,即皇后的位置是(k,st.col[k])。對于(i,j)位置上的皇后與已經(jīng)放置的皇后(k,st.col[k])發(fā)生沖突的情況時,則有:st.col[k]==j;對角線的沖突情況是:|j-st.col[k]|==|k-i|。</p><p> void queen(int n)//求解n皇后問題</p
19、><p><b> {</b></p><p> int i,j,k;</p><p> bool find;</p><p> Type st;//定義棧st</p><p> st.top=0;//初始化棧頂指針</p><p> st.top++;//將(1,
20、1)放進棧</p><p> st.col[st.top]=1;</p><p> while(st.top>0)//棧不空時循環(huán)</p><p><b> {</b></p><p> i=st.top;//當(dāng)前皇后為第i個皇后</p><p> if(st.top==n)//所
21、有皇后都放置好了,輸出一個解</p><p><b> {</b></p><p> printf("第%d個解:",++count);</p><p> for(k=1;k<=st.top;k++)</p><p> printf("(%d,%d)",k,st.co
22、l[k]);</p><p> printf("\n");</p><p><b> }</b></p><p> find=false;</p><p> for(j=1;j<=n;j++)</p><p><b> {</b></
23、p><p> if(place(st,i+1,j))//在i+1行找到一個放置皇后的位置(i+1,j)</p><p><b> {</b></p><p><b> st.top++;</b></p><p> st.col[st.top]=j;</p><p> f
24、ind=true;</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p> if(find==false)//在i+1行找不到放皇后的位置,回溯</p><p>
25、;<b> {</b></p><p> while(st.top>0)</p><p><b> {</b></p><p> if(st.col[st.top]==n)//本行也沒有可放的位置,則退棧</p><p><b> st.top--;</b>&l
26、t;/p><p> for(j=st.col[st.top]+1;j<=n;j++)//在本行的下一個位置找</p><p> if(place(st,st.top,j))</p><p><b> {</b></p><p> st.col[st.top]=j;</p><p><
27、;b> break;</b></p><p><b> }</b></p><p> if(j>n)//當(dāng)前皇后在本行沒有可放的位置</p><p> st.top--;//退棧</p><p> else//本行找到一個位置后,推出回溯</p><p><
28、b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> vo
29、id main() //主函數(shù)</p><p><b> {</b></p><p><b> int n;</b></p><p> printf("請輸入皇后個數(shù)n=");</p><p> scanf("%d",&n);</p>
30、;<p> printf("%d皇后問題求解如下:\n",n);</p><p><b> queen(n);</b></p><p> printf("\n");</p><p><b> }</b></p><p> 完整程序代碼及
31、運行結(jié)果截圖</p><p> #include <stdio.h></p><p> #include <stdlib.h></p><p> #define MaxSize 100</p><p> typedef struct</p><p><b> {</b&
32、gt;</p><p> int col[MaxSize];//col[i]存放第i個皇后的列號</p><p> int top;//棧頂指針</p><p> }StType;//定義順序棧類型</p><p> int count=0;</p><p> bool place(StType st,int
33、 i,int j)//測試(i,j)是否與1~i-1皇后有沖突</p><p><b> {</b></p><p><b> int k=1;</b></p><p> if(i==1) return true;//存放第一個皇后時沒有沖突</p><p> while(k<=i-1
34、)//j=1到k-1是已經(jīng)放置了皇后的列</p><p><b> {</b></p><p> if((st.col[k]==j)||(abs(j-st.col[k])==abs(k-i)))</p><p> return false;</p><p><b> k++;</b><
35、/p><p><b> }</b></p><p> return true;</p><p><b> }</b></p><p> void queen(int n)//求解n皇后問題</p><p><b> {</b></p>
36、<p> int i,j,k;</p><p> bool find;</p><p> StType st;//定義棧st</p><p> st.top=0;//初始化棧頂指針</p><p> st.top++;//將(1,1)放進棧</p><p> st.col[st.top]=1;&
37、lt;/p><p> while(st.top>0)//棧不空時循環(huán)</p><p><b> {</b></p><p> i=st.top;//當(dāng)前皇后為第i個皇后</p><p> if(st.top==n)//所有皇后都放置好了,輸出一個解</p><p><b>
38、{</b></p><p> printf("第%d個解:",++count);</p><p> for(k=1;k<=st.top;k++)</p><p> printf("(%d,%d)",k,st.col[k]);</p><p> printf("\n&q
39、uot;);</p><p><b> }</b></p><p> find=false;</p><p> for(j=1;j<=n;j++)</p><p> if(place(st,i+1,j))//在i+1行找到一個放置皇后的位置(i+1,j)</p><p><b&
40、gt; {</b></p><p><b> st.top++;</b></p><p> st.col[st.top]=j;</p><p> find=true;</p><p><b> break;</b></p><p><b>
41、}</b></p><p> if(find==false)//在i+1行找不到放皇后的位置,回溯</p><p><b> {</b></p><p> while(st.top>0)</p><p><b> {</b></p><p> if
42、(st.col[st.top]==n)//本行也沒有可放的位置,則退棧</p><p><b> st.top--;</b></p><p> for(j=st.col[st.top]+1;j<=n;j++)//在本行的下一個位置找</p><p> if(place(st,st.top,j))</p><p&g
43、t;<b> {</b></p><p> st.col[st.top]=j;</p><p><b> break;</b></p><p><b> }</b></p><p> if(j>n)//當(dāng)前皇后在本行沒有可放的位置</p><
44、p> st.top--;//退棧</p><p> else//本行找到一個位置后,推出回溯</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p>&l
45、t;b> }</b></p><p><b> }</b></p><p> void main()</p><p><b> {</b></p><p><b> int n;</b></p><p> printf(&q
46、uot;請輸入皇后個數(shù)n=");</p><p> scanf("%d",&n);</p><p> printf("%d皇后問題求解如下:\n",n);</p><p><b> queen(n);</b></p><p> printf("\
47、n");</p><p><b> }</b></p><p><b> 心得體會</b></p><p> 善于學(xué)習(xí)別人,多請教牛人,才會更快提高自己。有些問題也許就是自己在某一點想不通,想法轉(zhuǎn)不過來,這就消耗了很多時間。而經(jīng)過牛人的點撥問題就解決了,牛人們也會更直接,更清晰的教導(dǎo)一些技術(shù),通過向他們學(xué)習(xí)
48、,才會更快的提高自己的技能。</p><p> 多找一些題目來練習(xí),多敲代碼,才會更有感覺。在練習(xí)的過程中找出規(guī)則,形成編程思想。</p><p> 小組合作形成共同進步。小組成員的討論過程中,將各自的想法提出來,分析優(yōu)缺點,這過程中每個成員也可以學(xué)習(xí)到其他成員的解題思想,也可以審視自己的解題思想,獲得提升。</p><p><b> 參考文獻<
溫馨提示
- 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. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(八皇后問題)
- 課程設(shè)計——數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(八皇后問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計──n皇后八皇后
- 課程設(shè)計數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(八皇后問題)
- 數(shù)據(jù)結(jié)構(gòu)課程設(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è)計報告
- 數(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è)計報告---農(nóng)夫過河問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計—校園導(dǎo)航問題報告
評論
0/150
提交評論