版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 課 程 設(shè) 計(jì) 報(bào) 告</p><p> 課程設(shè)計(jì)名稱:數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</p><p> 課程設(shè)計(jì)題目: 約瑟夫環(huán)模擬</p><p> 院(系):計(jì)算機(jī)學(xué)院</p><p> 專 業(yè):計(jì)算機(jī)科學(xué)與技術(shù)</p><p><b> 1 課程設(shè)計(jì)介紹</b>&
2、lt;/p><p> 1.1 課程設(shè)計(jì)內(nèi)容</p><p> 由一個(gè)雙向循環(huán)鏈表模擬m個(gè)人站成一個(gè)圈,輸入一個(gè)數(shù)n,n>0正向前進(jìn),n<0逆向前進(jìn),當(dāng)前人由1開始計(jì)數(shù),每行進(jìn)一個(gè)人,計(jì)數(shù)加1,數(shù)到|n|的人出圈,然后依原行進(jìn)方向繼續(xù)由1開始計(jì)數(shù),重復(fù)上述過程,直到所有人都出圈,輸出其出圈序列。</p><p> 1.2 課程設(shè)計(jì)要求</p>
3、<p> 程序正常運(yùn)行,并將出圈順序以動(dòng)態(tài)方法表示出來。</p><p><b> 2 課程設(shè)計(jì)原理</b></p><p> 2.1 課設(shè)題目粗略分析</p><p> 根據(jù)課設(shè)題目要求,將整體程序分為查找和刪除兩大模塊:</p><p> 在查找模塊中,當(dāng)輸入的n的數(shù)值大于0時(shí),鏈表正向循環(huán)
4、且輸出第n人所在位置并調(diào)用刪除模塊釋放當(dāng)前節(jié)點(diǎn),直到所有人都出圈;當(dāng)輸入的n值小于0時(shí)鏈表逆向循環(huán)且輸出第n人所在位置并調(diào)用刪除模塊釋放當(dāng)前節(jié)點(diǎn),直到所有人出圈。</p><p> 刪除模塊負(fù)責(zé)將查找模塊找到的當(dāng)前人的節(jié)點(diǎn)進(jìn)行刪除并返回下一個(gè)人的位置。</p><p><b> 2.2 原理圖介紹</b></p><p> 2.2.1 功
5、能模塊圖</p><p> 如圖2.1所示為約瑟夫環(huán)模擬程序的功能模塊圖,函數(shù)包括查找模塊和刪除模塊,主函數(shù)中調(diào)用了查找模塊, 查找模塊中調(diào)用了刪除模塊。</p><p> 圖2.1 功能模塊圖</p><p> 2.2.2 流程圖分析</p><p> 主程序是整個(gè)程序的核心部分,通過對(duì)子函數(shù)JosephLink的調(diào)用,完成整個(gè)程序
6、,主函數(shù)流程圖表示如圖2.2所示: </p><p> 圖2.2主函數(shù)流程圖</p><p> 子函數(shù)JosephLink,主要功能為從當(dāng)前人開始查找第到|n|個(gè)人的位置并輸出第|n|個(gè)人所在位置,然后將第|n|個(gè)節(jié)點(diǎn)傳入函數(shù)del_link,流程圖如圖2.3所示:</p><p> 圖2.3子函數(shù)JosephLink流程圖</p><p&
7、gt; 子函數(shù)del_link1,主要功能為將由函數(shù)JosephLink查找到的節(jié)點(diǎn)進(jìn)行刪除操作并將該節(jié)點(diǎn)的下一節(jié)點(diǎn)返回到函數(shù)JosephLink中,流程圖如圖2.4所示:</p><p> 圖2.4 del_link1函數(shù)流程圖</p><p> 子函數(shù)del_link2,主要功能為將由函數(shù)JosephLink查找到的節(jié)點(diǎn)進(jìn)行刪除操作并將該節(jié)點(diǎn)的上一節(jié)點(diǎn)返回到函數(shù)JosephLin
8、k中,流程圖如圖2.5所示:</p><p> 圖2.5 del_link2函數(shù)流程圖</p><p><b> 3 數(shù)據(jù)結(jié)構(gòu)分析</b></p><p><b> 3.1 存儲(chǔ)結(jié)構(gòu)</b></p><p> 程序中主要用到的存儲(chǔ)結(jié)構(gòu)為雙向循環(huán)鏈表,其存儲(chǔ)結(jié)構(gòu)體為:</p>
9、<p> typedef struct DulNode{</p><p><b> int data;</b></p><p> struct DulNode*prev;</p><p> struct DulNode*next;</p><p><b> }DulNode;</b&g
10、t;</p><p> 該結(jié)構(gòu)體包括數(shù)據(jù)域和前指針prev域與后指針next域。</p><p><b> 3.2 算法描述</b></p><p> 創(chuàng)建雙向循環(huán)鏈表,簡(jiǎn)單算法說明如下:</p><p> person=(DulNode*)malloc(sizeof(DulNode)); //為第一個(gè)節(jié)點(diǎn)
11、申請(qǐng)空間</p><p> person->data=1; // data記錄當(dāng)前人的位置</p><p> person->next=person->prev=person;</p><p><b> s=person;</b></p><p&
12、gt; for(i=2;i<=m;i++){ //創(chuàng)建m-1個(gè)節(jié)點(diǎn)</p><p><b> r=s;</b></p><p> s=(DulNode*)malloc(sizeof(DulNode));</p><p> s->data=i;</p><p&
13、gt; s->prev=r; //依次將新生成的節(jié)點(diǎn)插入循環(huán)鏈表中</p><p> r->next->prev=s;</p><p> s->next=r->next;</p><p> r->next=s;}</p><p> 刪除節(jié)點(diǎn)tmp的算法
14、,如下所示:</p><p> tmp->prev->next=tmp->next; //將tmp前一個(gè)節(jié)點(diǎn)的next指 </p><p> //針指向tmp的下一個(gè)節(jié)點(diǎn)</p><p> tmp->next->prev=tmp->prev;//將tmp下一個(gè)節(jié)
15、點(diǎn)的prev指針//指向tmp的上一個(gè)節(jié)點(diǎn)</p><p><b> 4 調(diào)試與分析</b></p><p><b> 4.1 調(diào)試過程</b></p><p> 在調(diào)試程序時(shí)主要遇到以下幾個(gè)問題:</p><p> 調(diào)試時(shí)發(fā)現(xiàn)在鏈表上刪除節(jié)點(diǎn)之后無法繼續(xù)將下一個(gè)節(jié)點(diǎn)作為開始來循環(huán)而且當(dāng)輸
16、入的n的值為n的整數(shù)倍時(shí)無法正常輸出出圈序列。</p><p> 問題分析及解決辦法:專門創(chuàng)建一個(gè)刪除函數(shù),負(fù)責(zé)刪除傳入的節(jié)點(diǎn)并返回刪除節(jié)點(diǎn)的下一節(jié)點(diǎn),另外申請(qǐng)一個(gè)節(jié)點(diǎn)傳入鏈表的表頭。</p><p> 當(dāng)鏈表中節(jié)點(diǎn)只剩下一個(gè)的時(shí)候發(fā)現(xiàn)無法輸出最后節(jié)點(diǎn)所在的位置。</p><p> 問題分析及解決辦法:在循環(huán)中添加一個(gè)判斷條件,當(dāng)鏈表中只剩唯一一個(gè)節(jié)點(diǎn)的時(shí)候單
17、獨(dú)輸出節(jié)點(diǎn)所在的位置。</p><p> 調(diào)試過程中發(fā)現(xiàn)在刪除第一個(gè)節(jié)點(diǎn)之后鏈表不能繼續(xù)前進(jìn)n個(gè)位置并輸出第n個(gè)位置的序列。 問題分析及解決辦法:當(dāng)?shù)谝粋€(gè)節(jié)點(diǎn)被刪除后,將第一個(gè)節(jié)點(diǎn)后的節(jié)點(diǎn)作為頭結(jié)點(diǎn)。</p><p> 調(diào)試過程中發(fā)現(xiàn)程序運(yùn)行時(shí)不能按照正常的順序輸出出圈序列,后經(jīng)過多次細(xì)心調(diào)試及同學(xué)幫助才發(fā)現(xiàn)是全局變量和局域變量發(fā)生沖突而導(dǎo)致。</p
18、><p> 解決辦法:將全局變量和局域變量分別用不同的字母表示加以區(qū)分,經(jīng)過調(diào)試后輸出正常。</p><p><b> 5 運(yùn)行結(jié)果</b></p><p><b> 如圖:</b></p><p><b> 參考文獻(xiàn)</b></p><p>
19、[1] 嚴(yán)蔚敏,吳偉民.數(shù)據(jù)結(jié)構(gòu)(C語言版)[M].北京:清華大學(xué)出版社,2007.</p><p> [2] 呂英國(guó).算法設(shè)計(jì)與分析[M].北京:清華大學(xué)出版社,2006. </p><p> [3] 徐寶文 李志.C程序設(shè)計(jì)語言[M].北京:機(jī)械工業(yè)出版社,2004.</p><p> [4] 張長(zhǎng)海,陳娟.C程序設(shè)計(jì)[M].北京:高等教育出版社,2004
20、.</p><p> [5] 譚浩強(qiáng).C程序設(shè)計(jì)[M].北京:清華大學(xué)出版社,2005.</p><p> [6] 張千帆.數(shù)據(jù)結(jié)構(gòu)與算法(C語言實(shí)現(xiàn))[M].北京:科學(xué)出版社,2009</p><p> [7] 徐寶文 李志 . C程序設(shè)計(jì)語言[M] . 北京:機(jī)械工業(yè)出版社,2004</p><p> 附 錄(關(guān)鍵部分程序清單
21、)</p><p><b> 程序代碼</b></p><p> #include<stdio.h> </p><p> #include<stdlib.h></p><p> #include<malloc.h></p><p> typede
22、f struct DulNode</p><p><b> {</b></p><p><b> int data;</b></p><p> struct DulNode*prev;</p><p> struct DulNode*next;</p><p><
23、;b> }DulNode;</b></p><p> DulNode*del_link1(DulNode*person,DulNode*tmp,int m)</p><p> { /* n>0 刪除第n個(gè)節(jié)點(diǎn)打印本次操作結(jié)果并返回后一個(gè)節(jié)點(diǎn)信息*/</p><p> DulN
24、ode*s=tmp;</p><p><b> int i=0;</b></p><p> DulNode*head;</p><p> if(tmp!=person)</p><p> head=person;</p><p><b> else</b></
25、p><p> head=person->next;</p><p> tmp->prev->next=tmp->next;</p><p> tmp->next->prev=tmp->prev;</p><p> s=s->next;</p><p> free(t
26、mp);</p><p> printf("\n");</p><p><b> if(m>1)</b></p><p><b> {</b></p><p> for(i=0;i<m;i++)</p><p><b> {
27、</b></p><p> printf("%d ",head->data);</p><p> head=head->next;</p><p><b> }</b></p><p> printf("\n");</p><p&
28、gt;<b> }</b></p><p><b> return s;</b></p><p><b> }</b></p><p> DulNode*del_link2(DulNode*person,DulNode*tmp,int m)</p><p> {
29、 /* n<0 刪除第n個(gè)節(jié)點(diǎn)打印本次操作結(jié)果并返回前一個(gè)節(jié)點(diǎn)信息*/</p><p> DulNode*s=tmp;</p><p><b> int i=0;</b></p><p> DulNode*head;</p><p> if(tmp!
30、=person)</p><p> head=person;</p><p><b> else </b></p><p> head=person->next;</p><p> tmp->prev->next=tmp->next;</p><p> tmp-&
31、gt;next->prev=tmp->prev;</p><p> s=s->prev;</p><p> free(tmp);</p><p> printf("\n");</p><p><b> if(m>1)</b></p><p>&l
32、t;b> {</b></p><p> for(i=0;i<m;i++)</p><p><b> {</b></p><p> printf("%d ",head->data);</p><p> head=head->next;</p>
33、<p><b> }</b></p><p> printf("\n");</p><p><b> }</b></p><p><b> return s;</b></p><p><b> }</b></p
34、><p> void JosephLink(DulNode*person,int m,int n)</p><p> { /* 查找并打印第n個(gè)節(jié)點(diǎn)*/</p><p><b> int i;</b></p><p> DulNode*tmp=person;</p&g
35、t;<p><b> if(n>0)</b></p><p><b> {</b></p><p> while(tmp->next!=tmp)</p><p><b> {</b></p><p> for(i=1;i<n;i++)&
36、lt;/p><p><b> {</b></p><p> tmp=tmp->next;</p><p><b> }</b></p><p> printf("出圈數(shù)據(jù)為:\n%d \n圈中剩余數(shù)據(jù)為:",tmp->data);</p><p
37、><b> m--;</b></p><p> if(tmp==person)</p><p> person=person->next;</p><p> tmp=del_link1(person,tmp,m);</p><p><b> }</b></p>&
38、lt;p> printf("%d\n",tmp->data);</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> while(tmp->pre
39、v!=tmp)</p><p><b> {</b></p><p> for(i=1;i<-n;i++)</p><p><b> {</b></p><p> tmp=tmp->prev;</p><p><b> }</b>&
40、lt;/p><p> printf("出圈數(shù)據(jù)為:\n%d \n圈中剩余數(shù)據(jù)為:",tmp->data);</p><p><b> m--;</b></p><p> if(tmp==person)</p><p> person=person->next;</p>&
41、lt;p> tmp=del_link2(person,tmp,m);</p><p><b> }</b></p><p> printf("%d\n",tmp->data);</p><p><b> }</b></p><p><b> }&l
42、t;/b></p><p> void main()</p><p><b> {</b></p><p> DulNode*person,*s,*r;</p><p> int i,m,n;</p><p> printf("請(qǐng)輸入人數(shù)m:\n");</
43、p><p> scanf("%d",&m);</p><p> printf("請(qǐng)輸入n的值:\n");</p><p> scanf("%d",&n);</p><p> printf("約瑟夫環(huán)為:\n");</p><
44、p> if(m%2==1)</p><p><b> {</b></p><p> for(i=1;i<=m/2+1;i++)</p><p> printf("%d ",i);</p><p> printf("\n");</p><p&
45、gt; for(i=m;i>m/2+1;i--)</p><p> printf("%d ",i);</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p>
46、<p> for(i=1;i<=m/2;i++)</p><p> printf("%d ",i);</p><p> printf("\n");</p><p> for(i=m;i>m/2;i--)</p><p> printf("%d ",i
47、);</p><p><b> }</b></p><p> printf("\n");</p><p> printf("出圈動(dòng)態(tài)為:\n");</p><p> person=(DulNode*)malloc(sizeof(DulNode));</p>&
48、lt;p> person->data=1;</p><p> person->next=person->prev=person;</p><p><b> s=person;</b></p><p> for(i=2;i<=m;i++)</p><p><b> {<
49、;/b></p><p><b> r=s;</b></p><p> s=(DulNode*)malloc(sizeof(DulNode));</p><p> s->data=i;</p><p> s->prev=r;</p><p> r->next-&g
50、t;prev=s;</p><p> s->next=r->next;</p><p> r->next=s;</p><p><b> }</b></p><p> printf("\n");</p><p> JosephLink(person,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)_約瑟夫環(huán)_課程設(shè)計(jì)
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)“約瑟夫環(huán)”
- 約瑟夫環(huán)課程設(shè)計(jì)----數(shù)據(jù)結(jié)構(gòu)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--- 約瑟夫(joseph)環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--- 約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告(約瑟夫環(huán))
- 數(shù)據(jù)結(jié)構(gòu)--約瑟夫環(huán)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---約瑟夫環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--約瑟夫環(huán)
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)的課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---約瑟夫(joseph)環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)約瑟夫(joseph)環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告約瑟夫環(huán)完整版[1]
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)約瑟夫環(huán)問題
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---joseph環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---joseph環(huán)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--電梯模擬
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼
評(píng)論
0/150
提交評(píng)論