版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計</b></p><p> 題 目: 排序系統(tǒng)設(shè)計(約瑟夫環(huán)問題) </p><p> 班 級: </p><p> 姓 名: 學(xué) 號 <
2、;/p><p> 同組人姓名: </p><p> 起 迄 日 期: 2010年12月26日 </p><p> 課程設(shè)計地點: E3-A513 </p><p> 指導(dǎo)教師:
3、 </p><p> 完成日期:2011年12月</p><p><b> 摘要:</b></p><p> 功能:設(shè)編號為1,2,3,……,n的n(n>0)個人按順時針方向圍坐一圈,每個人持有一個正整數(shù)密碼。開始時任選一個正整數(shù)做為報數(shù)上限m,從第一個人開始順時針方向自1起順序報
4、數(shù),報到m是停止報數(shù),報m的人出列,將他的密碼作為新的m值,從他的下一個人開始重新從1報數(shù)。如此下去,直到所有人全部出列為止。令n最大值取30。要求設(shè)計一個程序模擬此過程,求出出列編號序列。</p><p><b> 目 錄</b></p><p><b> 1需求分析2</b></p><p><b>
5、; 1.1功能分析2</b></p><p><b> 1.2設(shè)計平臺2</b></p><p><b> 2概要設(shè)計2</b></p><p> 2.1創(chuàng)建循環(huán)單鏈表create()2</p><p> 2.2輸出查找search()3</p><
6、;p> 2.3異常處理及屏幕清理clean()3</p><p> 3程序設(shè)計主要流程4</p><p> 3.1程序?qū)崿F(xiàn)流程圖4</p><p> 4調(diào)試與操作說明4</p><p><b> 4.1調(diào)試情況4</b></p><p><b> 4.2操作說
7、明5</b></p><p><b> 總 結(jié)7</b></p><p><b> 致 謝8</b></p><p><b> 附 錄9</b></p><p> 參 考 文 獻13</p><p><b>
8、; ==1==</b></p><p><b> 1. 需求分析</b></p><p><b> 1.1 功能分析 </b></p><p> 本次選做的課程設(shè)計是改進約瑟夫(Joseph)環(huán)問題。我選擇了和羅源兩個人來完成本次課程設(shè)計的作業(yè)。約瑟夫環(huán)問題是一個古老的數(shù)學(xué)問題,本次課題要求用程序語言的
9、方式解決數(shù)學(xué)問題。此問題僅使用單循環(huán)鏈表就可以解決此問題。</p><p> 在建立單向循環(huán)鏈表時,因為約瑟夫環(huán)的大小由輸入決定。為方便操作,我們將每個結(jié)點的數(shù)據(jù)域的值定為生成結(jié)點時的順序號和每個人持有的密碼。進行操作時,用一個指針r指向當(dāng)前的結(jié)點,指針H指向頭結(jié)點。然后建立單向循環(huán)鏈表,因為每個人的密碼是通過scanf()函數(shù)輸入隨機生成的,所以指定第一個人的順序號,找到結(jié)點,不斷地從鏈表中刪除鏈結(jié)點,直到鏈
10、表剩下最后一個結(jié)點,通過一系列的循環(huán)就可以解決改進約瑟夫環(huán)問題。</p><p><b> 1.2設(shè)計平臺</b></p><p> Windows2007操作系統(tǒng);Microsoft Visual C++ 6.0;</p><p><b> 2.概要設(shè)計</b></p><p> 已知n個
11、人(以編號1,2,3...n分別表示)圍成一圈。從編號為1的人開始報數(shù),數(shù)到m的那個人出列;他的下一個人又從1開始報數(shù),數(shù)到m的那個人又出列;依此規(guī)律重復(fù)下去,直到一圈的人全部出列。這個就是約瑟夫環(huán)問題的實際場景,有一種是要通過輸入n,m,k三個正整數(shù),來求出列的序列。這個問題采用的是典型的循環(huán)鏈表的數(shù)據(jù)結(jié)構(gòu),就是將一個鏈表的尾元素指針指向隊首元素。r->next=H。解決問題的核心步驟:首先建立一個具有n個鏈結(jié)點,無頭結(jié)點的循環(huán)
12、鏈表。然后確定第1個報數(shù)人的位置。最后不斷地從鏈表中刪除鏈結(jié)點,直到鏈表為空。</p><p> 本課程設(shè)計主要采用了結(jié)構(gòu)體,程序中包含了兩個只要函數(shù):create();search();</p><p> 2.1 創(chuàng)建循環(huán)單鏈表create()</p><p> dtypeef struct Node 定義一個結(jié)構(gòu)體,m為密碼,n為序號(總?cè)藬?shù))。</
13、p><p><b> ==2==</b></p><p> 定義H=NULL創(chuàng)建一個沒有頭結(jié)點的單向循環(huán)鏈表,并采for(i=1;i<=z;i++)</p><p> 隨機輸入密碼,在每次輸入密碼后,自動生成新的鏈表存儲空間s=(Linklist)malloc(sizeof(Node));當(dāng)前指針r后移,并釋放r的值。直到r->=
14、H時創(chuàng)建單向循環(huán)鏈表成功,并返回H的值作為總?cè)藬?shù)。</p><p> 單項循環(huán)鏈表示意圖:</p><p> 每當(dāng)結(jié)點計數(shù)到某一結(jié)點時,將他的前驅(qū)結(jié)點接到他的后繼結(jié)點,然后將他的密碼值password賦給計數(shù)變量,再將此結(jié)點刪除。如此循環(huán)下去,直到最后變?yōu)榭盏膯窝h(huán)鏈表為止。</p><p> 2.2 輸出查找search()</p><p
15、> 用循環(huán)鏈表實現(xiàn)報數(shù)問題,利用count累計報數(shù)人數(shù),num為標(biāo)記出列人數(shù)計數(shù)器。當(dāng)隨機輸入初始密碼m0時即從第一個人報起,到第m時取出m并顯示,在釋放該指針指向m的值,從刪除位的下一個人開始報起,按該人的密碼為m實現(xiàn)對總個鏈表的輸出,指針沒報數(shù)一次則后移一個節(jié)點。</p><p> 實現(xiàn)代碼:pre->next=p->next;printf("%d ",p->
16、;n);m0=p->m;free(p); p=pre->next;</p><p> 2.3異常處理及屏幕清理clean() </p><p> system("cls"); 對上次輸入的及運行結(jié)果是否進行屏幕清理工作。使程序運行界面不至于太過混亂,也可以將第二次的實驗結(jié)果和先前的實驗結(jié)果進行比較從而可以發(fā)現(xiàn)程序是否出現(xiàn)運行錯誤,便于檢查和修改。&l
17、t;/p><p><b> ==3==</b></p><p> 3. 程序設(shè)計主要流程</p><p> 3.1 程序?qū)崿F(xiàn)流程圖(圖3-1)</p><p> 圖3-1 程序?qū)崿F(xiàn)流程圖 </p><p><b> 4.調(diào)試與操作說明</b></p>
18、<p><b> 4.1調(diào)試情況</b></p><p> 這次的課程設(shè)計的代碼很冗長,所以等有了解題思路后,把代碼都寫上后難免會有很多錯誤。當(dāng)?shù)谝淮伟颜麄€程序?qū)懞煤筮\行,出現(xiàn)了很多錯誤。如賦值語句H=NULL沒有定義,從而形成帶空頭結(jié)點的單鏈表,以及在操作r指針后移找出m時,沒對r當(dāng)時的值進行釋放從而導(dǎo)致下個輸出出現(xiàn)錯誤。不過經(jīng)過一點點的改正,錯誤也慢慢地變少。這也說明做事要
19、認(rèn)真,尤其做計算機這方面工作的時候,因為計算機不容許不一點點的錯誤,有了一點小錯誤和有一個大錯誤在計算機看來都是一樣的,都不會得不到結(jié)果。有些小錯誤,比如說少了個分號,變量忘了定義,數(shù)據(jù)溢出等都是些小錯誤,但也不能松懈。因為要注意的地方很多,經(jīng)過多次嘗試,問題也就自然而然的解決了,而且以后遇到這方面的問題都會覺得比較得心應(yīng)手。</p><p> 在調(diào)試的過程中,結(jié)構(gòu)體的優(yōu)勢很明顯,能很簡單的把問題解決,而不需要
20、使用的其他的一些比較復(fù)雜的方法。</p><p><b> ==4==</b></p><p><b> 4.2操作說明</b></p><p> 生成界面如圖4-1,4-2,4-3,4-4,4-5所示;</p><p><b> 圖 4-1 主菜單</b></p
21、><p> 圖4-2輸入約瑟夫環(huán)</p><p><b> ==5==</b></p><p> 當(dāng)程序運行的時候會出現(xiàn)如上圖所示的提示,要求使用者輸入程序中所需的輸入總?cè)藬?shù),使用者只需輸入自己所想的總?cè)藬?shù),便可以隨機輸入每個人對應(yīng)的密碼。最后系統(tǒng)會給出出列的次序。使用者還可進行選擇是否記錄上次數(shù)據(jù),進行下一次的操作。</p>
22、<p> 圖4-3顯示約瑟夫環(huán)問題</p><p><b> 圖4-4退出程序</b></p><p><b> ==6==</b></p><p> 圖4-5 當(dāng)輸入人數(shù)超過最大數(shù)</p><p><b> 總 結(jié)</b></p>&l
23、t;p> 為期一周的課程設(shè)計快結(jié)束了,通過這次數(shù)據(jù)結(jié)構(gòu)課程設(shè)計,我感受最深的就是對于循環(huán)鏈表的使用,可以說對循環(huán)鏈表有了比以前更進一步的認(rèn)識,以前只是一知半解的,如果只給個題目自己根本不能把程序完整地編寫出來,所以這次課程設(shè)計最大的收獲就在于對循環(huán)鏈表有了一定的理解,包括其中的一系列操作,如建立一個循環(huán)鏈表,刪除鏈表中的一個結(jié)點,增加一個結(jié)點等。</p><p> 在這次課程設(shè)計過程中需要我們一邊設(shè)計一
24、邊探索,這這個過程當(dāng)中我發(fā)現(xiàn)自己在數(shù)據(jù)結(jié)構(gòu)方面知識掌握不夠深入,對一些基本概念不能很好的理解,對一些數(shù)據(jù)結(jié)構(gòu)不能夠熟練的進行上機實現(xiàn),這是自己比較薄弱的。學(xué)好基礎(chǔ)知識是理論付諸實踐的前提,這樣理論和實踐才能充分地結(jié)合起來。在以后的學(xué)習(xí)中,我還要努力改正,充分利用上機實驗的機會提高自己。在程序的輸入的時候,因為自己對鍵盤的不熟練,代碼又很多很繁瑣,常常會產(chǎn)生放棄的念頭,從中我也</p><p><b>
25、 =7==</b></p><p> 感受到只有堅持到底,勝利才會出現(xiàn)。</p><p> 在調(diào)試程序的時候我也有所體會,雖然約瑟夫環(huán)問題不是很難,但調(diào)試的時候還是會出現(xiàn)很多錯誤,因此我們不能認(rèn)為容易就不認(rèn)真對待。在以后的學(xué)習(xí)中,要能不斷發(fā)現(xiàn)問題,提出問題,解決問題,從不足之處出發(fā),在不斷學(xué)習(xí)中提高自己。 </p><p><b> 致
26、謝</b></p><p> 這次的課程設(shè)計,我們兩人一個小組去完成我們自己的課程.,讓我們有機會貼近現(xiàn)實,感受成功的喜悅;其次要感謝實驗機房的老師提供優(yōu)良的實驗設(shè)備供我們做實驗,正是這種良好的實驗環(huán)境讓我們整個實驗過程心情都非常愉快。再次要感謝指導(dǎo)老師們的辛勤指導(dǎo),每當(dāng)我們遇到疑難問題時,是他們一次次不厭其煩的解釋和悉心的指導(dǎo),我們才能闖過一個個難關(guān),到達勝利的彼岸,是他們給我們提供了一次寶貴的
27、檢驗自己機會。只有在真正實戰(zhàn)的時候才會發(fā)現(xiàn)書到用時方恨少的真諦。有時感覺自己那么一次次舉手請教,可問題又那么幼稚簡單。老師是那么的耐心與不厭其煩,直到我們點頭說懂得的時候老師才離開。。最后也要感謝同學(xué)們的幫助,感謝所有在我課程設(shè)計過程中幫助過我的人!</p><p><b> ==8==</b></p><p><b> 附 錄</b>
28、</p><p> #include <stdio.h></p><p> #include <malloc.h></p><p> #include<conio.h></p><p> #include <stdlib.h></p><p> #include
29、<ctime></p><p> #define NULL 0</p><p> typedef struct Node</p><p><b> { </b></p><p> int m;//密碼</p><p> int n;//序號</p><p&
30、gt; struct Node *next;</p><p> }Node,*Linklist;</p><p> Linklist create(int z) //生成循環(huán)單鏈表并返回,z為總?cè)藬?shù)</p><p><b> { </b></p><p><b> int i,mm;</b&g
31、t;</p><p> Linklist H,r,s;</p><p><b> H=NULL;</b></p><p> printf("Output the code:");</p><p> for(i=1;i<=z;i++)</p><p><b&g
32、t; { </b></p><p> printf("\ninput cipher=");</p><p> scanf("%d",&mm);</p><p> s=(Linklist)malloc(sizeof(Node));</p><p><b> s-&
33、gt;n=i;</b></p><p><b> s->m=mm;</b></p><p> printf("%d號的密碼%d",i,s->m);</p><p> if(H==NULL)//從鏈表的第一個節(jié)點插入</p><p><b> { </
34、b></p><p><b> H=s;</b></p><p><b> r=H;</b></p><p><b> }</b></p><p> else//鏈表的其余節(jié)點插入</p><p><b> { </b&
35、gt;</p><p> r->next=s;</p><p><b> r=s;//r后移</b></p><p><b> }</b></p><p><b> }//for結(jié)束</b></p><p> r->next=H;/
36、*生成循環(huán)單鏈表*/</p><p><b> ==9==</b></p><p><b> return H;</b></p><p><b> }</b></p><p> void search(Linklist H,int m0,int z)//用循環(huán)鏈表實現(xiàn)報
37、數(shù)問題</p><p> { int count=1;//count為累計報數(shù)人數(shù)計數(shù)器</p><p> int num=0;//num為標(biāo)記出列人數(shù)計數(shù)器</p><p> Linklist pre,p;</p><p><b> p=H;</b></p><p> printf(&
38、quot;出列的順序為:");</p><p> while(num<z)</p><p><b> { </b></p><p><b> do{</b></p><p><b> count++;</b></p><p>&
39、lt;b> pre=p;</b></p><p> p=p->next;</p><p><b> }</b></p><p> while(count<m0);</p><p> pre->next=p->next;</p><p> pri
40、ntf("%d ",p->n);</p><p><b> m0=p->m;</b></p><p><b> free(p);</b></p><p> p=pre->next;</p><p><b> count=1;</b>
41、;</p><p><b> num++;</b></p><p> }//while結(jié)束</p><p><b> }</b></p><p> void clean()</p><p><b> {</b></p><p
42、> int system(const char *string);</p><p> int inquiry;</p><p> printf("請問需要清除上一次操作記錄嗎(1.清屏/2.不清屏)...?\n");</p><p> scanf("%d",&inquiry);</p>&
43、lt;p> if(inquiry ==1)</p><p> system("cls");</p><p><b> }</b></p><p> void text()</p><p><b> {</b></p><p> int
44、 m0,z,i, choose,k=1; //k用來阻止第一次進入程序清屏操作</p><p> Linklist H; </p><p> bool chooseFlag=false;</p><p><b> while(1)</b></p><p><b> {</b></p&
45、gt;<p><b> ==10==</b></p><p><b> if(k!=1)</b></p><p><b> clean();</b></p><p><b> k++;</b></p><p> while(!cho
46、oseFlag)</p><p><b> {</b></p><p> printf(" ……………………歡迎進入約瑟夫環(huán)問題系統(tǒng)…………………… \n");</p><p> printf(" * 1.輸入約瑟夫環(huán)數(shù)據(jù)
47、 * \n");</p><p> printf(" * 2.什么是約瑟夫環(huán) * \n");</p><p> printf(" * 3.退出系統(tǒng) * \n");printf(" ....................
48、.................................... \n");</p><p> printf("請輸入相應(yīng)的數(shù)字進行選擇: "); </p><p> scanf("%d",&choose);</p><p>
49、for(i=1;i<=4;i++)</p><p><b> {</b></p><p> if(choose==i) { chooseFlag=true; break;</p><p><b> }</b></p><p> else chooseFlag=false;</p&
50、gt;<p><b> }</b></p><p> if(!chooseFlag) printf("Error Input!\n");</p><p> } //end while(!chooseFlag)</p><p> if(choose==1) //if 開始</p><
51、p><b> {</b></p><p> printf("Input how many people in it:");//z為總?cè)藬?shù)</p><p> scanf("%d",&z);</p><p><b> if(z<=30)</b></p&g
52、t;<p><b> {</b></p><p> H=create(z);//函數(shù)調(diào)用</p><p> printf("\nInput the start code m0=");</p><p> scanf("%d",&m0);</p><p>
53、 search(H,m0,z);</p><p> printf("\n\n\n");</p><p><b> }</b></p><p><b> else </b></p><p><b> {</b></p><p>
54、; printf("超過最大輸入人數(shù)\n"); </p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> ==11==</b><
55、;/p><p> else if(choose==2)</p><p><b> {</b></p><p> printf("\n約瑟夫環(huán)問題:設(shè)有n個人,其編號分別為1,2,3,…,n,安裝編號順序順時針圍坐一圈。選定一個正整數(shù)m,從第一個人開始順時針報數(shù),</p><p> 報到m時,則此人出列,然后
56、從他的下一個人從1重新報數(shù),依此類推,直到所有人全部出列為止,求出列的順序。\n\n");</p><p><b> }</b></p><p> else if(choose==3)</p><p><b> {</b></p><p> printf("程序結(jié)束\n&
57、quot;);</p><p><b> break;</b></p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> printf(&qu
58、ot;錯誤!\n");</p><p><b> }//end if</b></p><p> chooseFlag=0;</p><p> }//end while(1)</p><p><b> }</b></p><p> void main()&l
59、t;/p><p><b> {</b></p><p> time_t timer ;/*時間*/</p><p> struct tm *ptrtime;/*指向struct tm的指針*/</p><p> timer = time( NULL ) ;/*調(diào)用time()函數(shù)獲取當(dāng)前時間*/</p>
60、<p> ptrtime = localtime( &timer ) ;/*調(diào)用localtime()函數(shù)將獲得的系統(tǒng)時間轉(zhuǎn)化為指向struct tm的指針指向的結(jié)構(gòu)體*/</p><p> printf(" 系統(tǒng)時間: %s",asctime( ptrtime ) ) ;/*用asctime()將結(jié)構(gòu)體轉(zhuǎn)化為字符串輸出*/&
61、lt;/p><p><b> text();}</b></p><p><b> ==12==</b></p><p><b> 參 考 文 獻</b></p><p> 1張乃孝,裘宗燕.數(shù)據(jù)結(jié)構(gòu)C++與面向?qū)ο蟮耐緩?北京:高等教育出版社,1998</p>
62、<p> 2 周云靜.?dāng)?shù)據(jù)結(jié)構(gòu)習(xí)題解析與上機指導(dǎo).北京:冶金工業(yè)出版社,2004</p><p> 3 陳慧南.?dāng)?shù)據(jù)結(jié)構(gòu)—C++語言描述.北京:人民郵電出版社,2005</p><p> 4 嚴(yán)蔚敏,吳偉民.?dāng)?shù)據(jù)結(jié)構(gòu).北京:清華大學(xué)出版社,1997</p><p> 5 Adam Drozdek.?dāng)?shù)據(jù)結(jié)構(gòu)與算法.北京:清華大學(xué)出版社,2006&l
溫馨提示
- 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ù)據(jù)結(jié)構(gòu)》課程設(shè)計“約瑟夫環(huán)”
- 約瑟夫環(huán)課程設(shè)計----數(shù)據(jù)結(jié)構(gòu)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--- 約瑟夫(joseph)環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--- 約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)模擬課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告(約瑟夫環(huán))
- 數(shù)據(jù)結(jié)構(gòu)--約瑟夫環(huán)課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---約瑟夫環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告--約瑟夫環(huán)
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)的課程設(shè)計報告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---約瑟夫(joseph)環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計約瑟夫(joseph)環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告約瑟夫環(huán)完整版[1]
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---joseph環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告---joseph環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計----huffman編碼
- 約瑟夫環(huán)-課程設(shè)計
評論
0/150
提交評論