版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 數(shù) 據(jù) 結(jié) 構(gòu)</b></p><p> 課 程 設(shè) 計 說 明 書</p><p> 2011年12月20日</p><p><b> 1.設(shè)計目的</b></p><p><b> 簡易文本編輯器</b></p><
2、p><b> 2.設(shè)計內(nèi)容和要求</b></p><p> 1) 具有圖形菜單界面;</p><p> 2) 查找,替換(等長,不等長),插入(插串,文本塊的插入)、塊移動(行塊,列塊移動),刪除</p><p> 3) 可正確存盤、取盤;</p><p> 4)
3、正確顯示總行數(shù)。</p><p> 3.本設(shè)計所采用的數(shù)據(jù)結(jié)構(gòu)</p><p> 本程序是對輸入的文字進(jìn)行操作,故使用的數(shù)據(jù)結(jié)構(gòu)為單鏈表操作</p><p> 線性表的鏈?zhǔn)酱鎯Y(jié)構(gòu)的特點(diǎn)是用一組任意的存儲單元存儲線性表的數(shù)據(jù)元素。它包括兩個域:其中存儲數(shù)據(jù)元素信息的域稱為數(shù)據(jù)域;存儲直接后繼存儲位置的域稱為指針域。另有全局變量*head,作為文章的頭指針。&
4、lt;/p><p> 在文章內(nèi)容創(chuàng)建部分中使用線性表的鏈?zhǔn)酱鎯Γ⑹褂萌肿兞繉ξ谋镜母鞣N信息進(jìn)行存儲;</p><p> 文章的內(nèi)容統(tǒng)計、刪除、查找、插入都采用鏈表操作完成。</p><p> 4.功能模塊詳細(xì)設(shè)計</p><p> 4.1 詳細(xì)設(shè)計思想</p><p> 本程序所定義函數(shù)的設(shè)計思想:</
5、p><p> CreatWord()文本內(nèi)容輸入函數(shù)</p><p> 定義LinkList指針變量*temp: LinkList *temp;</p><p> 定義文本輸入變量ch,記錄文本行數(shù)變量j,記錄每行字符數(shù)變量i;</p><p> 申請動態(tài)存儲空間:head->next=(LinkList *)malloc(siz
6、eof(LinkList));</p><p> 首行頭指針的前驅(qū)指針為空:head->pre=NULL;</p><p> 利用循環(huán)進(jìn)行文本輸入</p><p> PrintWord()當(dāng)前文本輸出函數(shù)</p><p> 定義文本行數(shù)變量j,每行字符數(shù)i:int i,j;</p><p> 定義指針變
7、量:LinkList *p;</p><p> 將指針p指向鏈表表頭: p=head->next;</p><p> 利用循環(huán)輸出鏈表中信息:</p><p> for(j=0;j<=NUM&&p!=NULL;j++)</p><p> {=for(i=0;(i<80)&&(p->
8、;data[i])!='#';i++)</p><p> {=printf("%c",p->data[i]);}</p><p> p=p->next; </p><p> SearchWord( ) 文本內(nèi)容查找函數(shù)</p><p> 定義一個數(shù)組,用來記錄需要查找的字符內(nèi)容:char
9、 Data[20];</p><p> 定義定義文本行數(shù)變量j,每行字符數(shù)i,記錄字符出現(xiàn)的次數(shù)變量:</p><p> 利用循環(huán)進(jìn)行查找操作,核心算法為:</p><p> if((temp->data[i])==Data[k]) </p><p> k++;//將輸入的查找字符與鏈表中信息比較,找到第一個相同的字符<
10、/p><p> else if(Data[k]!='\0')</p><p> {i=i-k; k=0; } // //從主串第i-k個位置重新查找</p><p> if(Data[k]=='\0') </p><p> {sum++;//此字符出現(xiàn)的次數(shù)加1</p><p>
11、i=i-k+1; //i記錄下該字符串出現(xiàn)的位置</p><p> printf("\t\t第%d次出現(xiàn)在第%d行第%d列\(zhòng)n",l,j+1,i);</p><p><b> l++;</b></p><p><b> k=0;</b></p><p> continue
12、;} </p><p> temp=temp->next; //指向下一行</p><p> DeleteWord( ) 文本內(nèi)容刪除函數(shù)</p><p> 定義一個數(shù)組用來存儲需要刪除的字符或者字符串:char Data[20];</p><p> 定義指針變量:LinkList *temp,*term;</p>
13、<p> 使用VC++中拷貝函數(shù)講形參中需要刪除的字符或字符串賦值給已定義的數(shù)組:</p><p> strcpy(Data,str2);</p><p> 使用循環(huán)進(jìn)行刪除操作:</p><p><b> 其核心算法為:</b></p><p> for(j=0;j<=NUM;j++) &l
14、t;/p><p> { for(i=0;i<80;i++) </p><p> { if((temp->data[i])==Data[k]) k++; </p><p> else if(Data[k]!='\0') {i=i-k;k=0;} </p><p> if(Data[k]=='\0'
15、) </p><p> {num=i;break; } } </p><p> if(num<80) break; }</p><p> 首先是使用循環(huán)查找到需要刪除字符或者字符串的字符數(shù)以及字符或者字符串的位置,以便于刪除;</p><p> for(;j<=NUM;j++) </p><p>
16、 { for(;i<80;i++) </p><p> { if(i+1<k) </p><p> { term->data[80-k+num]=temp->data[i+1]; } //刪除的字符串不在最后一行,將下一行的字符(由temp指向)前移到前行</p><p> else temp->data[i-k+1]=te
17、mp->data[i+1];} //當(dāng)要刪除的字符串在最后一行只要將最后一行的字符前移</p><p> term=temp;</p><p> temp=temp->next;</p><p> j=0;}//在使用循環(huán),從查找到的字符或者字符串開始進(jìn)行刪除,在一行刪除完畢之后,轉(zhuǎn)至下一行進(jìn)行刪除。</p><p>
18、 本程序所定義的函數(shù):</p><p> 1、HeadWord() 標(biāo)題函數(shù),即一個輸出標(biāo)題,永遠(yuǎn)出現(xiàn)在程序的最頂端。</p><p> 2、save() 文件存儲函數(shù)</p><p> 3、load() 文件讀取函數(shù)</p><p> 4、CreatWord() 文本輸入函數(shù)</p><p> 5、
19、PrintWord() 當(dāng)前文本內(nèi)容輸出函數(shù)</p><p> 6、SearchWord() 文章內(nèi)容查找函數(shù)</p><p> 7、DelWord() 文章內(nèi)容刪除函數(shù)</p><p> 8、InsertWord() 文章內(nèi)容插入函數(shù)</p><p> 9、Replace() 文章內(nèi)容替換函數(shù)</p><p
20、> 10、Bmenu() 第二子菜單函數(shù)</p><p> 11、menu() 主菜單函數(shù)</p><p> 12、main()主函數(shù)</p><p><b> 4.2 運(yùn)行結(jié)果</b></p><p> ?。?)執(zhí)行完menu() 主菜單函數(shù)后的結(jié)果</p><p><b&
21、gt; 輸入文章內(nèi)容的結(jié)果</b></p><p> (3)讀取當(dāng)前文本內(nèi)容信息</p><p> 進(jìn)入文本內(nèi)容處理菜單</p><p> ?。?)查找文章中字符或者字符串</p><p> ?。?)顯示當(dāng)前文章內(nèi)容</p><p><b> (7)返回主菜單</b></
22、p><p><b> 4.3 核心代碼</b></p><p> #include "stdafx.h"</p><p> #include "stdio.h"</p><p> #include "conio.h"</p><p>
23、 #include"malloc.h"</p><p> #include"string.h"</p><p> #include"iostream.h"</p><p> #include"stdlib.h"</p><p> #define Link
24、_Size 100</p><p> int NUM,C,N,hang; /*定義全局變量,Num用來記錄行號,C用來記錄子串在主串中出現(xiàn)的總次數(shù)*/</p><p> #define MAXLEN 80</p><p> char buffer[MAXLEN],fname[120];</p><p> char *lineptr[L
25、ink_Size];;</p><p><b> FILE *fp;</b></p><p> int modified=0,/*正文被修改標(biāo)志*/</p><p> last;/*當(dāng)前正文行數(shù)*/</p><p> char *chpt;/*輸入命令行字符指針*/</p><p> t
26、ypedef struct _list/*行表結(jié)構(gòu)*/</p><p><b> { </b></p><p> char data[80];/*記錄一行字符*/</p><p> int length;/*記錄一行字符長度*/</p><p> struct _list *next;/* 后繼指針*
27、/</p><p> struct _list *pre;/*前趨指針*/</p><p> int row;/*記錄整篇文章的行數(shù)*/</p><p> }LinkList;</p><p> LinkList *head; /*定義全局變量*head,文章首行頭指針*/</p><p> void
28、HeadWord()</p><p><b> {</b></p><p> printf("\t\t****************************************************\n");</p><p> printf("\t\t**** 歡迎使用簡單的文本編輯器
29、 ****\n");</p><p> printf("\t\t****************************************************\n");</p><p><b> }</b></p><p> int save(char *fname)</p
30、><p><b> {</b></p><p><b> int i;</b></p><p><b> FILE *fp;</b></p><p> char name[80];</p><p> if(!*fname)</p>&
31、lt;p><b> {</b></p><p> printf("filename:");</p><p> gets(name);</p><p><b> }</b></p><p> else strcpy(name,fname);</p>&
32、lt;p> if((fp=fopen(name,"wb"))==NULL)</p><p><b> return 0;</b></p><p> for(i=0;i<last;i++)</p><p><b> {</b></p><p> fputs(l
33、ineptr[i],fp);</p><p> free(lineptr[i]);</p><p><b> }</b></p><p> fclose(fp);</p><p> printf("file %s already saved.",name);</p><p&
34、gt;<b> getch();</b></p><p><b> return 1;</b></p><p><b> }</b></p><p> int load(char *fname)</p><p><b> {</b></p&
35、gt;<p><b> FILE *fp;</b></p><p> char ch,*p;</p><p><b> int i;</b></p><p> if((fp=fopen(fname,"rb"))==NULL) return 0;</p><p&g
36、t; while(!feof(fp))</p><p><b> {</b></p><p> ch=getc(fp);</p><p> if(ch=='\x09')</p><p> for(i=0;i<8;i++,p++) *p='\x20';</p>
37、<p> else if(ch!='\n'&&ch!=EOF)</p><p><b> {</b></p><p><b> *p=ch;</b></p><p><b> p++;</b></p><p><b>
38、 }</b></p><p><b> }</b></p><p><b> *p='\0';</b></p><p> fclose(fp);</p><p><b> }</b></p><p> LinkLi
39、st *CreatWord()</p><p><b> {</b></p><p> LinkList *temp;</p><p><b> char ch;</b></p><p> int i,j;/*記錄文本行數(shù)變量j,記錄每行字符數(shù)變量i*/</p><p&g
40、t; head->next=(LinkList *)malloc(sizeof(LinkList));</p><p> head->pre=NULL;</p><p> temp=head->next;</p><p> temp->pre=NULL;</p><p> temp->length=0;
41、</p><p> for(i=0;i<80;i++)</p><p> temp->data[i]='\0';</p><p> printf("開始創(chuàng)建文本,請輸入文章(按#結(jié)束):\n");</p><p> for(j=0;j<Link_Size;j++)</p>
42、;<p><b> {</b></p><p> for(i=0;i<80;i++)</p><p><b> {</b></p><p> ch=getchar();</p><p> temp->data[i]=ch;</p><p>
43、 temp->length++;</p><p> if(ch=='\n')</p><p><b> hang++;</b></p><p> if(ch=='#')</p><p><b> {</b></p><p>&l
44、t;b> NUM=j;</b></p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p> if(ch=='#')</p><p&g
45、t;<b> { </b></p><p> temp->length=i;</p><p> temp->next=NULL;</p><p><b> break;</b></p><p><b> }</b></p><p>
46、; temp->next=(LinkList *)malloc(sizeof(LinkList)) ;</p><p> temp->next->pre=temp;</p><p> temp=temp->next;</p><p> for(i=0;i<80;i++)</p><p> temp-&g
47、t;data[i]='\0';</p><p><b> }</b></p><p> temp->row=NUM+1;</p><p> system("cls");</p><p> return temp;</p><p><b>
48、 }</b></p><p> void PrintWord()</p><p><b> {</b></p><p> int i,j;/*記錄文本行數(shù)變量j,記錄每行字符數(shù)變量i*/</p><p> LinkList *p;</p><p> p=head->n
49、ext;</p><p> system("cls"); </p><p> HeadWord();</p><p> printf("\n當(dāng)前文章的內(nèi)容是:");</p><p> for(j=0;j<=NUM&&p!=NULL;j++)</p><p
50、><b> {</b></p><p> for(i=0;(i<80)&&(p->data[i])!='#';i++)</p><p><b> {</b></p><p> printf("%c",p->data[i]);</p&g
51、t;<p><b> }</b></p><p> p=p->next;</p><p><b> }</b></p><p> printf("\n當(dāng)前文章行數(shù)為:%d\n",hang);</p><p><b> }</b>
52、</p><p> void SearchWord(char *str1,LinkList* temp) </p><p><b> { </b></p><p> char Data[20] ; </p><p> int i,j,k=0,sum=0;</p><p>
53、<b> int l=1;</b></p><p> temp=head->next; </p><p> strcpy(Data,str1);</p><p> for(i=0;i<=NUM;i++) </p><p><b> { </b></p><p
54、> for(j=0;j<80;j++) </p><p><b> { </b></p><p> if((temp->data[j])==Data[k]) k++;</p><p> else if(Data[k]!='\0')</p><p><b> {<
55、/b></p><p><b> j=j-k;</b></p><p><b> k=0;</b></p><p><b> } </b></p><p> if(Data[k]=='\0') </p><p><b&
56、gt; {</b></p><p><b> sum++;</b></p><p><b> j=j-k+1;</b></p><p> printf("\t\t第%d次出現(xiàn)在第%d行第%d列\(zhòng)n",l,i+1,j+1);</p><p><b>
57、 l++;</b></p><p><b> k=0;</b></p><p> continue;} </p><p><b> } </b></p><p> temp=temp->next; </p><p><b> } <
58、/b></p><p> printf("\t\t\t字符串總共出現(xiàn)次數(shù)為:%d\n\n",sum); </p><p><b> C=sum;</b></p><p><b> N=i*80+j;</b></p><p><b> } </b&g
59、t;</p><p> void DelWord(char *str2) </p><p> {char Data[20];</p><p> LinkList *temp,*term; </p><p> int i,j,k,m,y,num;</p><p> str
60、cpy(Data,str2);</p><p> for(y=0;y<C;y++) </p><p><b> { </b></p><p><b> num=80;</b></p><p><b> k=0,m=0; </b></p><p&
61、gt; temp=head; </p><p> for(i=0;i<=NUM;i++) </p><p><b> { </b></p><p> term=temp; </p><p> temp=temp->next; </p><p> for(j=0;j<8
62、0;j++) </p><p><b> { </b></p><p> if((temp->data[j])==Data[k]) k++; </p><p> else if(Data[k]!='\0') {j=j-k;k=0;} </p><p> if(Data[k]=='\0
63、') </p><p><b> {</b></p><p><b> num=j;</b></p><p><b> break;</b></p><p><b> } </b></p><p><b>
64、 } </b></p><p> if(num<80) break; </p><p><b> } </b></p><p> for(;i<=NUM;i++) </p><p><b> { </b></p><p> for(;j&l
65、t;80;j++) </p><p><b> { </b></p><p> if(j+1<k) </p><p><b> { </b></p><p> term->data[80-k+num]=temp->data[j+1]; </p><p&g
66、t;<b> } </b></p><p><b> else</b></p><p> temp->data[j-k+1]=temp->data[j+1]; </p><p><b> } </b></p><p> term=temp; </p&
67、gt;<p> temp=temp->next;</p><p><b> j=0; </b></p><p><b> } </b></p><p><b> } </b></p><p><b> }</b></p&
68、gt;<p> LinkList * InsertWord(LinkList *temp)</p><p><b> { </b></p><p> char Data[20];</p><p><b> int h,l;</b></p><p> printf(&quo
69、t;\n\t\t請輸入要插入的字符或字符串:");</p><p> getchar();</p><p> gets(Data);</p><p> printf("\n\t\t當(dāng)前文章內(nèi)容為:");</p><p> PrintWord();</p><p> printf(
70、"\n\t\t請輸入要插入的行:");</p><p> scanf("%d",&h);</p><p> printf("\n\t\t請輸入要插入的列:");</p><p> scanf("%d",&l);</p><p> int i
71、=(h-1)*80+l;</p><p> LinkList *a;</p><p> int n=strlen(Data);</p><p><b> int m ;</b></p><p> int insertRow=i/80+1;</p><p> int row=temp-&g
72、t;row;</p><p><b> int j;</b></p><p> if(insertRow==row)</p><p><b> {</b></p><p> for(m=temp->length-1;m>=(i%80)&&n>0;m--)&
73、lt;/p><p> temp->data[m+n]=temp->data[m];</p><p> for(m=(i%80),j=0;m<n+(i%80);m++,j++)</p><p><b> {</b></p><p> temp->data[m]=Data[j];</p
74、><p><b> }</b></p><p><b> } </b></p><p><b> else</b></p><p><b> {</b></p><p><b> int r=0;</b>
75、;</p><p> for(int p=insertRow; p<row;p++)</p><p><b> {</b></p><p> if(p == insertRow) </p><p><b> r=0;</b></p><p><b>
76、 else</b></p><p><b> r=n;</b></p><p> for(m=temp->length-1-r;m>=0&&n>0;m--)</p><p> temp->data[m+n]=temp->data[m];</p><p>&l
77、t;b> a=temp;</b></p><p> temp = temp->pre;</p><p> temp->length = 80;</p><p> for(m = temp->length-n,j=0;m<temp->length;m++,j++)</p><p> a
78、->data[j]=temp->data[m];</p><p><b> }</b></p><p> for(m=temp->length-n-1;m>=(i%80);m--) </p><p> temp->data[m+n]=temp->data[m];</p><p>
79、 for(m=(i%80),j=0;m<(i%80)+n;m++,j++) </p><p> temp->data[m] =Data[j];</p><p><b> }</b></p><p> return temp;</p><p><b> }</b></p&g
80、t;<p> void Replace()</p><p><b> {</b></p><p> int k,m,n,i,j;</p><p> sscanf(chpt,"%d%d%d",&k,&m,&n); /* 讀入?yún)?shù) */</p><p> i
81、f(m<=0||m>last||n<m||last-(n-m+1)+k>=Link_Size)/* 檢查參數(shù)合理性 */</p><p><b> {</b></p><p> printf("Error!\n");</p><p><b> return;</b><
82、/p><p><b> }</b></p><p> /* 先完成刪除 */</p><p> if(n>last)</p><p> n=last; /* 修正參數(shù) */</p><p> for(i=m;i<=n;i++) /* 刪除正文 */</p>
83、<p> free(lineptr[i-1]);</p><p> for(i=m,j=n+1;j<=last;i++,j++)</p><p> lineptr[i-1]=lineptr[j-1];</p><p><b> last=i-1;</b></p><p> /* 以下完成插入
84、 */</p><p> for(i=last;i>=m;i--)</p><p> lineptr[i+k-1]=lineptr[i-1];</p><p> for(i=0;i<k;i++)</p><p><b> {</b></p><p> fgets(buffer
85、,MAXLEN,stdin);</p><p> lineptr[m+i-1]=(char *)malloc(strlen(buffer)+1);</p><p> strcpy(lineptr[m+i-1],buffer);</p><p><b> }</b></p><p> last+=k; /*
86、修正正文行數(shù) */</p><p> modified=1; /* 正文被修改 */</p><p><b> }</b></p><p> void Bmenu(LinkList *temp)</p><p><b> { </b></p><p> char
87、str1[20];</p><p> char str2[20];</p><p><b> int a;</b></p><p><b> do</b></p><p><b> {</b></p><p> HeadWord();</
88、p><p> printf("\n\t\t****************************************************\n");</p><p> printf("\t\t**** 文章內(nèi)容處理菜單 ****\n");</p><p> prin
89、tf("\t\t****************************************************\n");</p><p> printf("\t\t**** 1、查找文章中的字符或者字符串 ****\n");</p><p> printf("\t\t**** 2、刪除文章中的字
90、符或者字符串 ****\n");</p><p> printf("\t\t**** 3、向文章中插入字符或者字符串 ****\n");</p><p> printf("\t\t**** 4、替換文章中的字符或者字符串 ****\n");</p>&
91、lt;p> printf("\t\t**** 5、顯示當(dāng)前文章內(nèi)容 ****\n");</p><p> printf("\t\t**** 6、返回主菜單 ****\n");</p><p> printf("\t\t****
92、 7、直接退出系統(tǒng) ****\n");</p><p> printf("\t\t****************************************************\n");</p><p> printf("\t\t 請選擇:");</p>
93、<p> scanf("%d",&a);</p><p><b> switch(a)</b></p><p><b> {</b></p><p> case 1: </p><p> system("cls"); <
94、/p><p> HeadWord();</p><p> printf("\t\t\t請輸入您需要查找的字符或字符串:");</p><p> getchar();</p><p> gets(str1);</p><p> SearchWord(str1,temp);</p>
95、<p> printf("按回車鍵繼續(xù)·····");</p><p> getchar();</p><p> getchar();</p><p> system("cls");</p><p><b> break;&
96、lt;/b></p><p><b> case 2:</b></p><p> system("cls"); </p><p> HeadWord();</p><p> printf("\t\t\t請輸入您需要刪除的字符或字符串:");</p>&l
97、t;p> getchar();</p><p> gets(str2);</p><p> SearchWord(str2,temp);</p><p> DelWord(str2);</p><p> printf("\t\t\t刪除 %s 后的文章為:",str2);</p><p&
98、gt; PrintWord();</p><p> printf("按回車鍵繼續(xù)·····");</p><p> getchar();</p><p> getchar();</p><p> system("cls");</p>
99、<p><b> break;</b></p><p><b> case 3:</b></p><p> system("cls"); </p><p> HeadWord();</p><p> InsertWord(temp);</p>
100、<p> printf("\t\t\t插入字符或字符串后文章為:");</p><p> PrintWord();</p><p> printf("按回車鍵繼續(xù)·····");</p><p> getchar();</p><p>
101、; getchar();</p><p> system("cls");</p><p><b> break;</b></p><p><b> case 4:</b></p><p> system("cls"); </p><
102、;p> HeadWord();</p><p> Replace();</p><p> printf("\t\t\t替換字符或字符串后文章為:");</p><p> printf("按回車鍵繼續(xù)·····");</p><p> ge
103、tchar();</p><p> getchar();</p><p> system("cls");</p><p><b> break;</b></p><p><b> case 5:</b></p><p> system("
104、;cls"); </p><p> HeadWord();</p><p> PrintWord();</p><p> printf("按回車鍵繼續(xù)·····");</p><p> getchar();</p><p> ge
105、tchar();</p><p> system("cls");</p><p><b> break;</b></p><p><b> }</b></p><p> if(a==6) </p><p><b> {</b&g
106、t;</p><p> system("cls"); </p><p><b> break;</b></p><p><b> }</b></p><p> if(a==7) exit(0); </p><p> }while(1);
107、 </p><p><b> }</b></p><p> void menu(LinkList *temp)</p><p><b> {</b></p><p> char name[20];</p><p><b> int t;<
108、/b></p><p><b> do{</b></p><p> HeadWord();</p><p> printf("\n");</p><p> printf("\t\t*************************************************
109、***\n");</p><p> printf("\t\t**** 主菜單 ****\n");</p><p> printf("\t\t****************************************************\n");</p
110、><p> printf("\t\t**** 1、文章內(nèi)容輸入 ****\n");</p><p> printf("\t\t**** 2、保存文本 ****\n");</p><p> printf(&quo
111、t;\t\t**** 3、讀取文本 ****\n");</p><p> printf("\t\t**** 4、當(dāng)前文本內(nèi)容信息 ****\n");</p><p> printf("\t\t**** 5、進(jìn)入文章內(nèi)容處理菜單
112、 ****\n");</p><p> printf("\t\t**** 6、退出文本編輯器 ****\n");</p><p> printf("\t\t****************************************************\n"
113、;);</p><p> printf("\t\t**** 注:第一次運(yùn)行本程序時請選擇1號功能 ****\n");</p><p> printf("\t\t****************************************************\n");</p><p> printf(
114、" \t\t 請選擇:");</p><p> scanf("%d",&t);</p><p> if((t>6)&&(t<1))</p><p><b> { </b></p><p> printf("對不起,無此功
115、能,請輸入正確的功能序號!\n");</p><p><b> }</b></p><p><b> else</b></p><p><b> switch(t)</b></p><p><b> { </b></p>
116、<p><b> case 1: </b></p><p> system("cls"); </p><p> HeadWord();</p><p> temp=CreatWord();</p><p><b> break;</b></p>
117、<p><b> case 2: </b></p><p> save(name);</p><p><b> break;</b></p><p><b> case 3: </b></p><p> load(name);</p>&l
118、t;p><b> break;</b></p><p><b> case 4: </b></p><p> PrintWord();</p><p> printf("\n");</p><p> printf("按回車鍵繼續(xù)··
119、···");</p><p> getchar();</p><p> getchar();</p><p> system("cls");</p><p><b> break;</b></p><p><b> c
120、ase 5: </b></p><p> system("cls"); </p><p> Bmenu(temp);</p><p><b> break;</b></p><p><b> }</b></p><p> if(t=
121、=6) break;</p><p> }while(1);</p><p><b> }</b></p><p> void main()</p><p><b> {</b></p><p> head=(LinkList *)malloc(sizeof(Lin
122、kList));</p><p> LinkList *temp;</p><p> menu(temp);</p><p><b> }</b></p><p> 5.課程設(shè)計心得及存在問題</p><p> 本程序是在線性表的基礎(chǔ)上改進(jìn)的,用到了雙向鏈表和一些c++里面的知識。線性表
123、的操作數(shù)是浮點(diǎn)形,而文本編輯器的操作數(shù)是字符型,在線性表的程序上加進(jìn)插入刪除查找數(shù)據(jù)結(jié)構(gòu),然后建立一個文件保存線性表中的數(shù)據(jù),就是我寫的程序。</p><p> 本次課程設(shè)計還算順利,但是在設(shè)計過程中由于自己的不細(xì)心,忽略了一些關(guān)鍵的細(xì)節(jié),導(dǎo)致了在編寫過程中出現(xiàn)了一些錯誤。例如:少了分號,或忘了定義函數(shù),又如能運(yùn)行但輸出結(jié)果錯誤,結(jié)果不正確。又由于自己打字時犯得小錯誤,導(dǎo)致出現(xiàn)不易發(fā)現(xiàn)的錯誤,最終在老師及編程能
124、力比較強(qiáng)的同學(xué)幫助下,查找到并及時改正。</p><p> 該程序不僅可以利用線性表還可以利用串、單鏈表司實(shí)現(xiàn),通過做該程序,我又對課本做了新的解讀,加深了對所學(xué)知識的印象及了解,同時也了解了我還有許多不足,對許多所學(xué)過的知識掌握得不夠透徹,不夠深入,應(yīng)用不夠靈活,今后我會彌補(bǔ)這方面的不足,加深理解課本知識,同時注重應(yīng)用。</p><p> 通過這次課程設(shè)計讓我又學(xué)到了很多東西,加深了
125、對數(shù)據(jù)結(jié)構(gòu)這門課程的理解和學(xué)會了如何在實(shí)際中應(yīng)用數(shù)據(jù)結(jié)構(gòu)編程。讓我了解到自己在這門課程上還存在很多缺陷,尤其是對文件操作問題。通過對線性表的應(yīng)用,查找課本資料加深了對線性表的了解,并學(xué)會了靈活運(yùn)用。通過調(diào)試,我學(xué)會了借助逐步調(diào)試功能和數(shù)據(jù)窗口,加快找到程序中的錯誤點(diǎn),調(diào)試能力有所提高。</p><p> 本程序中運(yùn)用了大量的循環(huán)結(jié)構(gòu)和條件結(jié)構(gòu),在編寫程序時要注意條件的判斷和循環(huán)條件的正確編寫。該程序中程序代碼較
126、多,引用較多指針和定義的許多變量,理解起來較難。而且對于文件的存儲和讀取還是存在問題。有待于我自己進(jìn)一步再去研究這段程序,并且改進(jìn)它。我現(xiàn)在初步的解決辦法是定義一個類,類里包含一些靜態(tài)的屬性和動態(tài)的函數(shù),然后在繼承這些函數(shù)。這樣可以簡化程序代碼,然后精確存取的文件路徑,使之在文件的存取方面便于更好的理解,使程序功能更全面。</p><p> 總之,通過本次課程設(shè)計,不僅鍛煉了我的實(shí)際操作能力,而且培養(yǎng)了嚴(yán)密的思
溫馨提示
- 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 文本編輯器課程設(shè)計報告
- 微機(jī)原理課程設(shè)計—簡易文本編輯器
- 文本編輯器課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---簡易文本編輯器
- vb課程設(shè)計報告----文本編輯器
- vb課程設(shè)計報告---文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--簡易文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-簡易文本編輯器
- java課程設(shè)計--文本編輯器
- java課程設(shè)計---文本編輯器
- java課程設(shè)計---文本編輯器
- vb課程設(shè)計文本編輯器
- java課程設(shè)計(文本編輯器)
- c語言課程設(shè)計--文本編輯器
- c_文本編輯器課程設(shè)計
- 文本編輯器_java課程設(shè)計實(shí)驗(yàn)報告
- visual_basic課程設(shè)計報告---文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--文本編輯器
- 操作系統(tǒng)課程設(shè)計---文本編輯器
- java 課程設(shè)計報告---用 java 設(shè)計文本編輯器mytxt
評論
0/150
提交評論