版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 前 言</b></p><p> 一.本課程設(shè)計(jì)意義 </p><p> 課程設(shè)計(jì)是實(shí)踐性教學(xué)中的一個(gè)重要環(huán)節(jié),它以某一課程為基礎(chǔ),可以涉及和課程相關(guān)的各個(gè)方面,是一門(mén)獨(dú)立于課程之外的特殊課程。課程設(shè)計(jì)是讓同學(xué)們對(duì)所學(xué)的課程更全面的學(xué)習(xí)和應(yīng)用,理解和掌握課程的相關(guān)知識(shí)。《數(shù)據(jù)結(jié)構(gòu)》是一門(mén)重要的專(zhuān)業(yè)基礎(chǔ)課,是計(jì)算機(jī)理論和應(yīng)用的核心基礎(chǔ)課
2、程。</p><p> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì),要求學(xué)生在數(shù)據(jù)結(jié)構(gòu)的邏輯特性和物理表示、數(shù)據(jù)結(jié)構(gòu)的選擇和應(yīng)用、算法的設(shè)計(jì)及其實(shí)現(xiàn)等方面,加深對(duì)課程基本內(nèi)容的理解。同時(shí),在程序設(shè)計(jì)方法以及上機(jī)操作等基本技能和科學(xué)作風(fēng)方面受到比較系統(tǒng)和嚴(yán)格的訓(xùn)練。</p><p> 二.本課程設(shè)計(jì)的目的和任務(wù)</p><p> 1.提高對(duì)數(shù)據(jù)邏輯結(jié)構(gòu)的特點(diǎn)以及存儲(chǔ)表示方式的認(rèn)識(shí),培養(yǎng)在
3、具體應(yīng)用中選擇合適的數(shù)據(jù)結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu)的能力。</p><p> 2.熟悉軟件開(kāi)發(fā)的基本過(guò)程,初步掌握軟件開(kāi)發(fā)過(guò)程的問(wèn)題分析、系統(tǒng)設(shè)計(jì)、程序編碼、測(cè)試等階段基本任務(wù)和技能方法。</p><p> 3.培養(yǎng)自己的算法設(shè)計(jì)和算法分析能力,提高綜合運(yùn)用所學(xué)的理論知識(shí)和方法獨(dú)立分析和解決問(wèn)題的能力。</p><p> 4.訓(xùn)練用系統(tǒng)的觀點(diǎn)和軟件開(kāi)發(fā)一般規(guī)范進(jìn)行軟件開(kāi)發(fā)
4、,培養(yǎng)軟件工作者所應(yīng)具備的工作方法、作風(fēng)和相互合作的精神。</p><p> 5.綜合運(yùn)用鏈表的查找、插入和刪除,理論結(jié)合實(shí)際,將其運(yùn)用到文章編輯這一實(shí)驗(yàn)中。使這些知識(shí)得到進(jìn)一步鞏固、加深和拓展。利用模塊的思想,模塊之間用指針連接,減少了不必要的麻煩。鞏固加深指針的用途,理解模塊的優(yōu)點(diǎn)。加深對(duì)鏈表的理解,全面認(rèn)識(shí)鏈表操作的字符串的模式匹配操作。</p><p><b> 需
5、求 分 析</b></p><p> 本實(shí)驗(yàn)所要實(shí)現(xiàn)的功能:輸入一頁(yè)文字,程序可以統(tǒng)計(jì)出文字、數(shù)字、空格的個(gè)數(shù)。靜態(tài)存儲(chǔ)一頁(yè)文章,每行最多不超過(guò)80個(gè)字符,共N行;</p><p><b> 要求:</b></p><p> ?。?)分別統(tǒng)計(jì)出其中英文字母數(shù)和空格數(shù)及整篇文章總字?jǐn)?shù);</p><p>
6、(2)統(tǒng)計(jì)某一字符串在文章中出現(xiàn)的次數(shù),并輸出該次數(shù);</p><p> ?。?)刪除某一子串,并將后面的字符前移。</p><p> 存儲(chǔ)結(jié)構(gòu)使用線(xiàn)性表,分別用幾個(gè)子函數(shù)實(shí)現(xiàn)相應(yīng)的功能;</p><p> 輸入數(shù)據(jù)的形式和范圍:可以輸入大寫(xiě)、小寫(xiě)的英文字母、任何數(shù)字及標(biāo)點(diǎn)符號(hào)。</p><p><b> 輸出形式:</
7、b></p><p> ?。?)分行輸出用戶(hù)輸入的各行字符;</p><p> ?。?)分4行輸出"全部字母數(shù)"、"數(shù)字個(gè)數(shù)"、 "空格個(gè)數(shù)"和"文章總字?jǐn)?shù)"</p><p> 輸出刪除某一字符串后的文章;</p><p> 用鏈表存放數(shù)據(jù)非常靈活,只要
8、內(nèi)存足夠大,對(duì)鏈表可以做任意擴(kuò)充和修改。</p><p> 主要的手段為鏈表的遍歷。定義一個(gè)頭指針head,每個(gè)結(jié)點(diǎn)的數(shù)據(jù)域存放數(shù)據(jù)本身,指針域存放下一個(gè)結(jié)點(diǎn)地址,所以,我們只要知道head,就可以遍歷整個(gè)鏈表,找到我們所需要的字符(串),進(jìn)行相應(yīng)的操作。</p><p><b> 概 要 設(shè) 計(jì)</b></p><p><b>
9、 一.輸入模塊</b></p><p> 存儲(chǔ)結(jié)構(gòu):采用單鏈表結(jié)構(gòu)存儲(chǔ)文章,每個(gè)結(jié)點(diǎn)存儲(chǔ)一行,每行最長(zhǎng)不超過(guò)80個(gè)字符。</p><p><b> 結(jié)構(gòu)定義:</b></p><p> typedef struct line{</p><p> char *data; //字符串指針需要時(shí)
10、動(dòng)態(tài)分配內(nèi)存</p><p> struct line *next;</p><p><b> }LINE;</b></p><p> 算法描述:用gets函數(shù)接收輸入,每遇到一個(gè)回車(chē)換行就新建一個(gè)結(jié)點(diǎn),將當(dāng)前行存入其data域。當(dāng)發(fā)現(xiàn)輸入為^E時(shí),在Data的最后加上字符串結(jié)束標(biāo)志,并置當(dāng)前結(jié)點(diǎn)的Next指針域?yàn)镹ULL。</p&
11、gt;<p><b> 二.統(tǒng)計(jì)模塊</b></p><p> 統(tǒng)計(jì)模塊包括統(tǒng)計(jì)全部字母數(shù),統(tǒng)計(jì)數(shù)字個(gè)數(shù),統(tǒng)計(jì)空格個(gè)數(shù),以及統(tǒng)計(jì)文章總字?jǐn)?shù),這四個(gè)部分的實(shí)現(xiàn)算法大體相同,四者的關(guān)系是:全部字母數(shù)+數(shù)字個(gè)數(shù)+空格個(gè)數(shù)=文章總字?jǐn)?shù),也就是說(shuō)可以在統(tǒng)計(jì)出其中三者的前提下計(jì)算出第四個(gè)的數(shù)量。</p><p> 另外一個(gè)重要的統(tǒng)計(jì)功能是統(tǒng)計(jì)某一字符串在整篇文
12、章中出現(xiàn)的次數(shù),這個(gè)需要用到串的模式匹配算法來(lái)實(shí)現(xiàn)。</p><p><b> 三.刪除模塊</b></p><p> 刪除模塊的算法思想類(lèi)同統(tǒng)計(jì)字符串的算法思想,由于采用了鏈表的存儲(chǔ)結(jié)構(gòu),使得刪除算法的時(shí)間復(fù)雜度大大減少。</p><p> void Del_String(LINE * &head,char *sch){ //刪
13、除指定的字符串</p><p> LINE *p=head;</p><p><b> do</b></p><p><b> {</b></p><p> while(strstr(p->data,sch)!=NULL)del_string_word(p->data,sch);
14、</p><p> } while((p=p->next)!=NULL); //遍歷鏈表 </p><p><b> 詳細(xì)設(shè)計(jì)</b></p><p> 文章輸入、瀏覽、統(tǒng)計(jì)串、統(tǒng)計(jì)及刪除的詳細(xì)流程如下圖4-1所示:</p><p><b> 回車(chē)
15、回車(chē)回車(chē)</b></p><p><b> Ctrl+E</b></p><p><b> 回車(chē)</b></p><p><b> 回車(chē)</b></p><p><b> 回車(chē)</b></p><p><
16、;b> 回車(chē)</b></p><p><b> 回車(chē)</b></p><p><b> 回車(chē)回車(chē)</b></p><p><b> 回車(chē)</b></p><p> 回車(chē) 回車(chē)</p>&
17、lt;p><b> 回車(chē)</b></p><p><b> 圖4-1</b></p><p> 程序的具體代碼如下:</p><p> #include <iostream.h></p><p> #include <string.h></p>
18、<p> #include <stdio.h></p><p> #include <stdlib.h></p><p> #include <windows.h></p><p> typedef struct line{</p><p> char *data; //字符串
19、指針需要時(shí)動(dòng)態(tài)分配內(nèi)存</p><p> struct line *next;</p><p><b> }LINE;</b></p><p> void CreateTXT(LINE * &head); //創(chuàng)建一張列表,同時(shí)向里面輸入文本數(shù)據(jù)</p><p> int Count_Space(LINE
20、 * &head); //統(tǒng)計(jì)空格數(shù)</p><p> int Count_ZM(LINE * &head); // 統(tǒng)計(jì)字母數(shù)</p><p> int Count_All_Word(LINE * &head); //統(tǒng)計(jì)文章的總字?jǐn)?shù)</p><p> int Find_Word(LINE * &head,char *sc
21、h); //統(tǒng)計(jì)sch 在文章中出現(xiàn)的次數(shù)</p><p> int Count_Num(LINE * &head); //統(tǒng)計(jì)數(shù)字?jǐn)?shù)</p><p> void Del_String(LINE * &head,char *sch); //刪除指定的字符串</p><p> void OutPutTxt(LINE * &head); /
22、/向屏幕輸出文章</p><p> void Tj(LINE * &head); //統(tǒng)計(jì)</p><p> int read_text(LINE * &head);</p><p> int free_link(LINE *&head);</p><p> int free_link(LINE *&h
23、ead)</p><p><b> {</b></p><p> LINE *p=head;</p><p><b> do</b></p><p> {p->data=NULL;</p><p> free(p->data);</p>
24、<p><b> }</b></p><p> while((p=p->next)!=NULL);</p><p> head->next=NULL;</p><p><b> return 0;</b></p><p><b> }</b>
25、</p><p> void setcolor(unsigned short color) </p><p><b> { </b></p><p> HANDLE hCon = GetStdHandle(STD_OUTPUT_HANDLE); </p><p> SetConsoleTextAttribute(
26、hCon,color); </p><p><b> } </b></p><p> void CreateTXT(LINE * &head){</p><p> LINE *p=new LINE; //首先為鏈表 建立一個(gè)附加表頭結(jié)點(diǎn)</p><p> head=p; //將p付給 表頭指針</
27、p><p> char tmp[80];</p><p><b> while(1)</b></p><p><b> {</b></p><p> gets(tmp); //輸入字符串!使用C的輸入函數(shù)</p><p> if(tmp[0]==5)break;
28、//如果發(fā)現(xiàn)輸入 ^E,則退出輸入 </p><p> p->data=new char[strlen(tmp)+1];//為結(jié)點(diǎn)分配空間 </p><p> strcpy(p->data,tmp);</p><p> if(tmp[strlen(tmp)-1]==5){ //除去最后一個(gè)控制符 ^E <
29、/p><p> p->data[strlen(tmp)-1]='\0';</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p> p->
30、;next=NULL; //是最后的一個(gè)指針為空。</p><p> head=head->next;</p><p><b> }</b></p><p> int Count_Space(LINE * &head){ //統(tǒng)計(jì)空格數(shù)</p><p> LINE *p=head;</p&g
31、t;<p> int asc_space=32; //空格的ASCIC 碼值</p><p> int count=0;</p><p><b> do</b></p><p><b> { </b></p><p> int Len=strlen(p->
32、data); //計(jì)算當(dāng)前 data 里的數(shù)據(jù)元素的個(gè)數(shù)</p><p> for(int i=0;i<Len;i++)</p><p> if(p->data[i]==asc_space)count++; //計(jì)算空格數(shù)</p><p><b> } </b></p><p&g
33、t; while((p=p->next)!=NULL); //遍歷鏈表</p><p> return count;</p><p><b> }</b></p><p> int Count_Num(LINE * &head){ //統(tǒng)計(jì)數(shù)字?jǐn)?shù)</p><p> LINE *p=head;
34、</p><p> int count=0;</p><p><b> do</b></p><p><b> { </b></p><p> int Len=strlen(p->data); //計(jì)算當(dāng)前 data 里的數(shù)據(jù)元素的個(gè)數(shù)</p&g
35、t;<p> for(int i=0;i<Len;i++)</p><p> if(p->data[i]>=48 && p->data[i]<=57)count++; //計(jì)算數(shù)字?jǐn)?shù)</p><p><b> } </b></p><p> while((p=p->
36、;next)!=NULL); //遍歷鏈表</p><p> return count;</p><p><b> }</b></p><p> int Count_ZM(LINE * &head){ // 統(tǒng)計(jì)字母數(shù)</p><p> int count=Count_All_Word(head
37、); //總的字符數(shù),包含空格</p><p> int space_count=Count_Space(head); //空格數(shù)</p><p> int num_count=Count_Num(head);//數(shù)字?jǐn)?shù)</p><p> return count-space_count-num_count; //返回文章的字母總數(shù)</p>&
38、lt;p><b> }</b></p><p> int Count_All_Word(LINE * &head){ //統(tǒng)計(jì)文章的總字?jǐn)?shù)</p><p> LINE *p=head; //保存鏈表的首地址</p><p> int count=0; //總字母數(shù)</p><p><b&
39、gt; do</b></p><p> {count+=strlen(p->data);} //計(jì)算當(dāng)前行內(nèi)的字符數(shù)</p><p> while((p=p->next)!=NULL); //遍歷鏈表</p><p> return count;</p><p><b> }</b
40、></p><p> int Find_Word(LINE * &head,char *sch){ //統(tǒng)計(jì) sch 在文章中出現(xiàn)的次數(shù)</p><p> LINE *p=head;</p><p> int count=0;</p><p> // int h=0;</p><p> int
41、len1=0; //保存當(dāng)前行的總字符數(shù)</p><p> int len2=strlen(sch); //待統(tǒng)計(jì)字符串的長(zhǎng)度</p><p> int i,j,k;</p><p><b> do</b></p><p><b> {</b></p><p> l
42、en1=strlen(p->data);//當(dāng)前行的字符數(shù)</p><p> for(i=0;i<len1;i++)</p><p><b> { </b></p><p> if(p->data[i]==sch[0])</p><p><b> {</b></
43、p><p><b> k=0;</b></p><p> for(j=0;j<=len2-1;j++)</p><p> if(p->data[i+j]==sch[j])k=k+1;</p><p> if(k==len2){count++;i=i+k-1;}</p><p>&l
44、t;b> }</b></p><p><b> }</b></p><p><b> } </b></p><p> while((p=p->next)!=NULL); //遍歷鏈表</p><p> return count;</p>&
45、lt;p><b> }</b></p><p> void del_string_word(char *s,char *sch)</p><p><b> {</b></p><p> // *s為輸入的字符串</p><p> // *sch 為將要?jiǎng)h除的字符</p>
46、<p> char *p=strstr(s,sch); //查詢(xún)結(jié)果</p><p> char tmp[80];</p><p> int len=strlen(s);</p><p> int i=len-strlen(p);</p><p> int j=i+strlen(sch);</p>&
47、lt;p> int count=0;</p><p> for(int k=0;k<i;k++)tmp[count++]=s[k];</p><p> for(int kk=j;kk<len;kk++)tmp[count++]=s[kk];</p><p> tmp[count]='\0';</p><p
48、> strcpy(s,tmp); //返回新的字符串</p><p><b> }</b></p><p> void Del_String(LINE * &head,char *sch){ //刪除指定的字符串</p><p> LINE *p=head;</p><p><b> d
49、o</b></p><p><b> {</b></p><p> while(strstr(p->data,sch)!=NULL)del_string_word(p->data,sch);</p><p> } while((p=p->next)!=NULL); //遍歷鏈表</p>
50、<p><b> }</b></p><p> void OutPutTxt(LINE * &head){ //向屏幕輸出文章</p><p> LINE *p=head;</p><p><b> do</b></p><p> { cout<<p
51、->data<<endl;</p><p> } while((p=p->next)!=NULL); //遍歷 鏈表</p><p><b> }</b></p><p> void Tj(LINE * &head){ //統(tǒng)計(jì)</p><p> cout<<
52、;"文章統(tǒng)計(jì)信息結(jié)果如下:"<<endl;</p><p> cout<<"英文字母數(shù):"<<Count_ZM(head)<<endl;</p><p> cout<<"空格數(shù): "<<Count_Space(head)<<endl;</
53、p><p> cout<<"文章中共出現(xiàn)數(shù)字:"<<Count_Num(head)<<endl;</p><p> cout<<"統(tǒng)計(jì)文章的總字?jǐn)?shù): "<<Count_All_Word(head)<<endl;</p><p><b> }&l
54、t;/b></p><p> void main()</p><p><b> {</b></p><p> setcolor(10);</p><p> LINE *head;</p><p><b> int opt;</b></p>&l
55、t;p> cout<<"\n ***************************************請(qǐng)選擇操作**************************"<<endl;</p><p> cout<<" 1、新建 ";</p><p> cout<<"
56、2、瀏覽 ";</p><p> cout<<"3、統(tǒng)計(jì) ";</p><p> cout<<"4、串統(tǒng)計(jì) ";</p><p> cout<<"5、刪除 ";</p><p> cout&l
57、t;<"6、退出 "<<endl;</p><p><b> cin>>opt;</b></p><p> if(opt!=1)</p><p> {cout<<"第一次請(qǐng)務(wù)必選擇第1項(xiàng),以輸入文本以便操作"<<endl;</p&
58、gt;<p><b> opt = 0;</b></p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> //int n;int i;ElemTyp
59、e e;</p><p> while(opt!=6){</p><p><b> //</b></p><p> switch (opt) {</p><p><b> case 0:{</b></p><p> cout<<"\n ****
60、***********************************請(qǐng)選擇操作**************************"<<endl;</p><p> cout<<" 1、新建 ";</p><p> cout<<"2、瀏覽 ";</p><p
61、> cout<<"3、統(tǒng)計(jì) ";</p><p> cout<<"4、串統(tǒng)計(jì) ";</p><p> cout<<"5、刪除 ";</p><p> cout<<"6、退出 "<&l
62、t;endl;</p><p><b> cin>>opt;</b></p><p> if (opt!=1&&opt!=2&&opt!=3&&opt!=4&&opt!=5&&opt!=6)</p><p> {cout<<"
63、error!不可識(shí)別選項(xiàng)!"<<endl;exit(0);}</p><p><b> break;}</b></p><p> case 1:{cout<<"--------新建文本---------------"<<endl;</p><p> cout<<
64、"請(qǐng)輸入文本,每行最多輸入80字符!(結(jié)束請(qǐng)按 Ctrl + E)"<<endl;</p><p> setcolor(14);CreateTXT(head);setcolor(10);</p><p> cout<<endl<<"-------------------------------"<<
65、;endl;</p><p> cout<<"按回車(chē)調(diào)出主菜單……"<<endl;</p><p> getchar();</p><p> opt=0;break; }</p><p> case 2:{cout<<"--------瀏覽輸入文本---------
66、---"<<endl;</p><p> setcolor(14);OutPutTxt(head);setcolor(10);cout<<endl<<"-------------------------------"<<endl;</p><p> cout<<"按回車(chē)調(diào)出主菜單……&q
67、uot;<<endl;</p><p> getchar();opt=0;break; }</p><p> case 3:{cout<<"-----------文本統(tǒng)計(jì)-------------"<<endl;</p><p> setcolor(14);Tj(head);setcolor(10);
68、</p><p> cout<<endl<<"-------------------------------"<<endl;</p><p> cout<<"按回車(chē)調(diào)出主菜單……"<<endl;</p><p> getchar();opt=0;break;
69、 }</p><p> case 4:{cout<<"----請(qǐng)輸入要統(tǒng)計(jì)的字符串-----"<<endl;</p><p> setcolor(14); </p><p> char sch[20];</p><p> gets(sch);</p><p>
70、cout<<endl;</p><p> cout<<sch<<"出現(xiàn)的次數(shù)為:"<<Find_Word(head,sch)<<endl;</p><p> setcolor(10); </p><p> cout<<"--------------------
71、-----------"<<endl;</p><p> cout<<"按回車(chē)調(diào)出主菜單……"<<endl;</p><p> getchar();opt=0;break; }</p><p> case 5:{cout<<"------字符串刪除---------
72、---"<<endl;</p><p> setcolor(14);</p><p> cout<<"請(qǐng)輸入要?jiǎng)h除的某一字符串:"<<endl;</p><p> char tmp_sch[20];</p><p> //cin>>tmp_sch;</
73、p><p> gets(tmp_sch);</p><p> Del_String(head,tmp_sch); //刪除指定字符</p><p> cout<<"--------字符串 "<<tmp_sch<<" 被刪除后---------"<<endl;</p>
74、;<p> OutPutTxt(head); //向屏幕輸出 文章</p><p> setcolor(10);</p><p> cout<<endl<<"-------------------------------"<<endl;</p><p> cout<<&
75、quot;按回車(chē)調(diào)出主菜單……"<<endl;</p><p> getchar();opt=0;break;}</p><p> case 6:exit(0);</p><p><b> default:{</b></p><p> cout<<"請(qǐng)輸入1~6之
76、間的數(shù)字!"<<endl;</p><p> cout<<"按回車(chē)調(diào)出主菜單……"<<endl;</p><p> getchar();opt = 0;break;}</p><p> }//end of switch</p><p> free_link(head)
77、;//釋放鏈表空間</p><p> }//end of while</p><p> }//end of else</p><p><b> }</b></p><p> 調(diào)試過(guò)程的系統(tǒng)測(cè)試情況及問(wèn)題</p><p><b> 一.測(cè)試情況</b></p&g
78、t;<p> 程序運(yùn)行,首先顯示選擇菜單,如圖示:</p><p> 選擇1,輸入文章,界面運(yùn)行結(jié)果如下:</p><p> 按回車(chē),調(diào)出開(kāi)始菜單,輸入2,選擇瀏覽,可以原樣顯示出剛才輸入的文本:</p><p> 回車(chē)后輸入3,可以看到文章統(tǒng)計(jì)信息結(jié)果:</p><p><b> 根據(jù)頁(yè)面提示,回車(chē)<
79、/b></p><p> 統(tǒng)計(jì)字符串模塊,輸入要統(tǒng)計(jì)的字符串,可以查找出該字符串在文章中出現(xiàn)過(guò)的次數(shù)。運(yùn)行情況如下圖示:</p><p><b> 根據(jù)頁(yè)面提示,回車(chē)</b></p><p> 刪除模塊,輸入要?jiǎng)h除的字符串,執(zhí)行刪除后可以顯示刪除后的文本。界面如下:</p><p> 根據(jù)頁(yè)面提示,回車(chē):&
80、lt;/p><p> 退出頁(yè)面,執(zhí)行后的結(jié)果如下:</p><p><b> 二.問(wèn)題</b></p><p> 1 . 主流程進(jìn)入死循環(huán)。.</p><p> 解決方案:每個(gè)循環(huán)都加break,每跳出一個(gè)模塊,opt重新賦值為0。</p><p> 2.輸入多個(gè)變量,需要空格間隔時(shí),程序只
81、讀空格前的變量</p><p> 解決方案:輸.入函數(shù)用get( )函數(shù),形式為:get(tmp),即可解決著個(gè)問(wèn)題。</p><p> 3.不識(shí)別自定義函數(shù)。</p><p> 解決方案:函數(shù)定義前要函數(shù)聲明,若不聲明,則調(diào)用函數(shù)必須在函數(shù)定義之后,否則不識(shí)別。</p><p> 4.程序結(jié)束之后,鏈表仍占空間。</p>
82、;<p> 解決方案:在建立鏈表是所申請(qǐng)的內(nèi)存空間在程序結(jié)束之前用free_link(LINE *&head)函數(shù)釋放,即刪除鏈表中的全部結(jié)點(diǎn),且將鏈表頭指針置為空。</p><p><b> 三. 注意事項(xiàng):</b></p><p> ?。?)opt代表選項(xiàng)(共六個(gè),多于六個(gè)顯示“不可識(shí)別選項(xiàng)”)。</p><p>
83、 (2)建立文章,用鏈表存儲(chǔ),p=p->next=new LINE,即文章的每一行存儲(chǔ)在一個(gè)結(jié)點(diǎn)中。</p><p> (3)Ctrl+E為結(jié)束標(biāo)志。</p><p> ?。?)了解常用ASⅡ碼。</p><p><b> 課程設(shè)計(jì)總結(jié)</b></p><p> 本實(shí)驗(yàn)采用鏈?zhǔn)巾樞虮斫Y(jié)構(gòu)實(shí)現(xiàn)了文章編輯的基本
84、功能,實(shí)驗(yàn)過(guò)程中遇到了很多或大或小的問(wèn)題,在這些問(wèn)題的解決過(guò)程中,加深了對(duì)鏈表的理解,使我對(duì)鏈表操作的字符串的模式匹配有了更深更全面的認(rèn)識(shí)。</p><p> 本實(shí)驗(yàn)提高了我對(duì)數(shù)據(jù)邏輯結(jié)構(gòu)的特點(diǎn)和存儲(chǔ)表示方式的認(rèn)識(shí),培養(yǎng)了我在具體應(yīng)用中選擇合適的數(shù)據(jù)結(jié)構(gòu)和存儲(chǔ)結(jié)構(gòu)的能力。</p><p> 通過(guò)該實(shí)驗(yàn),我熟悉了軟件開(kāi)發(fā)的基本過(guò)程,初步掌握了軟件開(kāi)發(fā)過(guò)程的問(wèn)題分析、系統(tǒng)設(shè)計(jì)、程序編碼測(cè)試
85、等階段的基本任務(wù)和技能方法;使我的算法設(shè)計(jì)和算法分析能力以及運(yùn)用所學(xué)理論知識(shí)和方法獨(dú)立分析問(wèn)題的能力得到全面的提高;訓(xùn)練了我用系統(tǒng)的觀點(diǎn)和軟件開(kāi)發(fā)的一般規(guī)范。使我認(rèn)識(shí)到一個(gè)軟件工作者所應(yīng)該具備的科學(xué)的工作方法、作風(fēng)和相互合作精神。</p><p> 本實(shí)驗(yàn)的模塊化比較強(qiáng),各個(gè)模塊之間用指針head連接。認(rèn)清模塊化的概念給程序的順利編制起到了很大的作用。分模塊各個(gè)調(diào)試,可以減少很多不必要的麻煩。</p>
86、;<p><b> 參考文獻(xiàn)</b></p><p> [1] 嚴(yán)蔚敏、吳偉民主編,《數(shù)據(jù)結(jié)構(gòu)》(C語(yǔ)言版),清華大學(xué)出版社,2002。</p><p> [2] 殷人昆等著,《數(shù)據(jù)結(jié)構(gòu)》(C++版),清華大學(xué)出版社,2001。</p><p> [3] 金遠(yuǎn)平著,《數(shù)據(jù)結(jié)構(gòu)》(C++描述),清華大學(xué)出版社,2005。&l
87、t;/p><p> [4] 許卓群等著,《數(shù)據(jù)結(jié)構(gòu)與算法》,高等教育出版社,2004。</p><p> [5] Frank M.Carrano等著,《數(shù)據(jù)結(jié)構(gòu)與C++高級(jí)教程》,清華大學(xué)出版社,2004。</p><p> [6] 嚴(yán)蔚敏、吳偉民著,《數(shù)據(jù)結(jié)構(gòu)習(xí)題集》(C語(yǔ)言版),清華大學(xué)出版社。</p><p><b>
88、致 謝</b></p><p> 在這次課程設(shè)計(jì)的撰寫(xiě)過(guò)程中,我得到了許多人的幫助。</p><p> 首先我要感謝我的老師在課程設(shè)計(jì)上給予我的指導(dǎo)、提供給我的支持和幫助,這是我能順利完成這次報(bào)告的主要原因,更重要的是老師幫我解決了許多技術(shù)上的難題,讓我能把系統(tǒng)做得更加完善。在此期間,我不僅學(xué)到了許多新的知識(shí),而且也開(kāi)闊了視野,提高了自己的設(shè)計(jì)能力。</p>
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---文章編輯
- 文章編輯_數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 文章編輯_數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-文章編輯
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--文章編輯系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--文章編輯
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)—文章編輯設(shè)計(jì)報(bào)告
- c語(yǔ)言數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---文章編輯
- c語(yǔ)言數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-文章編輯
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--文章編輯集合運(yùn)算
- 高級(jí)數(shù)據(jù)結(jié)構(gòu)課程論文---文章編輯
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----行編輯程序
- 簡(jiǎn)單行編輯系統(tǒng)數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)——簡(jiǎn)單行編輯程序
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)(論文)任務(wù)書(shū)--棧和隊(duì)列及其應(yīng)用 文章編輯
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--文字編輯器
- c語(yǔ)言(數(shù)據(jù)結(jié)構(gòu))-文章編輯系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論