版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)總結(jié)報(bào)告</p><p> 設(shè)計(jì)題目:文本編輯器</p><p><b> 學(xué)生姓名: </b></p><p> 系 別:計(jì)算機(jī)科學(xué)與工程</p><p> 專 業(yè):計(jì)算機(jī)科學(xué)與技術(shù)</p><p> 班 級(jí):06-1</p
2、><p><b> 學(xué) 號(hào): </b></p><p><b> 指導(dǎo)教師: </b></p><p> 2008 年 12 月 20 日</p><p> 課 程 設(shè) 計(jì) 任 務(wù) 書</p><p> 題目 文本編輯器
3、 </p><p> 專業(yè)、班級(jí) 計(jì)科06-1 學(xué)號(hào) 26 姓名 羅啟福 </p><p><b> 主要內(nèi)容:</b></p><p> ?。?)打開文本文件(2)顯示文本內(nèi)容(3)插入文本行(可一次性插入多行)(4)刪除指定文本行(可一次性刪除多行)(5)拷貝指定的多行(6)修改行(7
4、)查找指定的字符串 (8)替換指定的字符串(支持全部替換) (9) 統(tǒng)計(jì)字?jǐn)?shù) (10) 存盤 (11)另存為 (12)系統(tǒng)菜單、右鍵菜單(右擊顯示框或其它地方)(13)附帶功能(游戲、系統(tǒng)時(shí)間、繪圖、記事本)</p><p><b> 基本要求:</b></p><p> 要求完成:輸出整篇文章內(nèi)容;在文章尾部追加一行;在文章指定行插入新行;修改文章指定行;刪除
5、文章指定行;統(tǒng)計(jì)某一字符串在文章中出現(xiàn)的次數(shù);統(tǒng)計(jì)文章的全部字母數(shù);統(tǒng)計(jì)文章的數(shù)字個(gè)數(shù);保存文章到磁盤指定文件;加載磁盤文章文件。</p><p> 運(yùn)行環(huán)境:WindowsXP, 帶有MFC基礎(chǔ)類庫的VC++6.0</p><p> 操作數(shù)據(jù):打開與應(yīng)用程序在同目錄下的me.txt 或file.dat,也可使用瀏覽功能打開任意文本文件,然后進(jìn)行各種操作。</p><
6、;p><b> 主要參考資料等:</b></p><p> 《數(shù)據(jù)結(jié)構(gòu)(C語言版)》 作者:嚴(yán)蔚敏 吳偉民 出版社:清華大學(xué)出版社</p><p> 《Visual C++程序設(shè)計(jì)--基礎(chǔ)與實(shí)例分析》作者:朱晴婷 等 出版社:清華大學(xué)出版社</p><p> 《數(shù)據(jù)結(jié)構(gòu)算法實(shí)現(xiàn)及解析》 作者:高一凡
7、 出版社:西安電子科技大學(xué)出版社</p><p> 完 成 期 限: 一周 </p><p> 指導(dǎo)教師簽名: </p><p> 課程負(fù)責(zé)人簽名: </p><p> 2008年 12 月 20 日</p><
8、;p><b> 目錄</b></p><p> 設(shè)計(jì)題目(任選其一)</p><p><b> 需求分析</b></p><p> 運(yùn)行環(huán)境(軟、硬件環(huán)境)</p><p><b> 算法設(shè)計(jì)的思想</b></p><p><b&g
9、t; 算法的流程圖</b></p><p><b> 算法設(shè)計(jì)分析</b></p><p><b> 源代碼</b></p><p><b> 運(yùn)行結(jié)果分析</b></p><p><b> 收獲及體會(huì)</b></p>
10、<p><b> 設(shè)計(jì)題目</b></p><p> 設(shè)計(jì)目的:文本編輯程序是一個(gè)面向用戶的系統(tǒng)服務(wù)程序,廣泛用于源程序的輸入和修改,甚至用于報(bào)刊和書籍的編輯排版以及辦公室的公文書信的起草和潤(rùn)色。</p><p> 設(shè)計(jì)內(nèi)容:文章編輯功能:輸入一頁文字,程序可以統(tǒng)計(jì)出文字、數(shù)字、空格的個(gè)數(shù)。靜態(tài)存儲(chǔ)一頁文章,每行最多不超過80個(gè)字符,共N行;要求(
11、1)分別統(tǒng)計(jì)出其中英文字母數(shù)和空格數(shù)及整篇文章總字?jǐn)?shù);(2)統(tǒng)計(jì)某一字符串在文章中出現(xiàn)的次數(shù),并輸出該次數(shù);(3)刪除某一子串,并將后面的字符前移。 存儲(chǔ)結(jié)構(gòu)使用線性表,分別用幾個(gè)子函數(shù)實(shí)現(xiàn)相應(yīng)的功能;輸入數(shù)據(jù)的形式和范圍:可以輸入大寫、小寫的英文字母、任何數(shù)字及標(biāo)點(diǎn)符號(hào)。輸出形式:(1)分行輸出用戶輸入的各行字符;(2)分4行輸出"全部字母數(shù)"、"數(shù)字個(gè)數(shù)"、"空格個(gè)數(shù)&q
12、uot;、"文章總字?jǐn)?shù)"(3)輸出刪除某一字符串后的文章;要求完成:輸出整篇文章內(nèi)容;在文章尾部追加一行;在文章指定行插入新行;修改文章指定行;刪除文章指定行;統(tǒng)計(jì)某一字符串在文章中出現(xiàn)的次數(shù);統(tǒng)計(jì)文章的全部字母數(shù);統(tǒng)計(jì)文章的數(shù)字個(gè)數(shù);保存文章到磁盤指定文件;加載磁盤文章文件。</p><p><b> 二.需求分析</b></p><p>
13、隨著個(gè)人電腦的迅速普及,各種實(shí)用的小型軟件的開發(fā)和設(shè)計(jì)也變得更要必要了。本軟件是為電腦使用者做文本編輯而精心設(shè)計(jì)的,可以滿足文本操作的大部分要求。</p><p> 文本編輯程序是一個(gè)面向用戶的系統(tǒng)服務(wù)程序,廣泛用于源程序的輸入和修改,甚至用于報(bào)刊和書籍的編輯排版以及辦公室的公文書信的起草和潤(rùn)色。</p><p><b> 功能模塊描述:</b></p>
14、;<p><b> 打開文件:</b></p><p> 該模塊的功能主要是用于打開文本文件用于編輯。用戶可直接輸入與之在同一個(gè)目錄下的說有文本文件,也可以實(shí)用瀏覽按鈕打開其它任何地方的任何文本文件。默認(rèn)文件名為me.txt,默認(rèn)路徑為同目錄。</p><p> 可使用“打開文件”按鈕,也可使用系統(tǒng)菜單中的“文件\打開”</p>&l
15、t;p><b> 2.顯示文本內(nèi)容:</b></p><p> 該模塊的功能是顯示已經(jīng)打開的文本文件。可使用“顯示文件內(nèi)容”按鈕,也可使用系統(tǒng)菜單中的“編輯\顯示”</p><p><b> 3.插入行:</b></p><p> 可使用“插入行”按鈕,也可使用系統(tǒng)菜單中的“編輯\插入行”或右鍵菜單中的“插入
16、行”打開插入行數(shù)據(jù)的對(duì)話框。在第一個(gè)輸入框中輸入插入的位置,在第二個(gè)輸入框中輸入插入的總行數(shù)。然后可以在彈出的輸入框中輸入要插入的數(shù)據(jù)。4.刪除行:</p><p> 可使用“刪除行”按鈕,也可使用系統(tǒng)菜單中的“編輯\刪除行” 或右鍵菜單中的“刪除行”打開刪除行數(shù)據(jù)的對(duì)話框。在第一個(gè)輸入框中輸入刪除的起始位置,在第二個(gè)輸入框中輸入刪除的總行數(shù)。</p><p><b> 5
17、.拷貝行:</b></p><p> 可使用“拷貝行”按鈕,也可使用系統(tǒng)菜單中的“編輯\拷貝行”打開拷貝行數(shù)據(jù)的對(duì)話框。在第一個(gè)輸入框中輸入拷貝的起始位置,在第二個(gè)輸入框中拷貝刪除的總行數(shù).在第三個(gè)輸入框中輸入要吧拷貝的數(shù)據(jù)插入的位置。</p><p><b> 6.修改行:</b></p><p> 可使用“修改行”按鈕,也
18、可使用系統(tǒng)菜單中的“編輯\修改行”打開修改行數(shù)據(jù)的對(duì)話框。在第一個(gè)輸入框中輸入修改的行位置,在彈出輸入框中輸入新數(shù)據(jù)內(nèi)容。</p><p><b> 7.查找字符串:</b></p><p> 可使用“查找字符串”按鈕,也可使用系統(tǒng)菜單中的“編輯\查找字符串”打開查找字符串?dāng)?shù)據(jù)的對(duì)話框。在輸入框中輸入要查找的字符串。</p><p><
19、;b> 8.替換字符串:</b></p><p> 可使用“替換字符串”按鈕,也可使用系統(tǒng)菜單中的“編輯\替換字符串”打開替換字符串?dāng)?shù)據(jù)的對(duì)話框。在第一個(gè)輸入框中輸入要替換的字符串,在第二個(gè)輸入框中輸入新數(shù)據(jù)內(nèi)容。</p><p><b> 9.存盤或另存為:</b></p><p> 該模塊可以保存文本內(nèi)容到指定的文
20、件。</p><p> 10.統(tǒng)計(jì)各種字符的個(gè)數(shù):</p><p> 該模塊可以統(tǒng)計(jì)出中文、英文、空格、數(shù)字及其它字符的個(gè)數(shù)和總字符數(shù)。</p><p><b> 11.附加功能:</b></p><p> 附加功能有游戲、繪圖、記事本及查看系統(tǒng)時(shí)間。</p><p><b>
21、 功能分析:</b></p><p> 本系統(tǒng)主要是用于文本編輯者的文檔編輯,文本編輯程序是一個(gè)面向用戶的系統(tǒng)服務(wù)程序,廣泛用于源程序的輸入和修改,甚至用于報(bào)刊和書籍的編輯排版以及辦公室的公文書信的起草和潤(rùn)色。</p><p><b> 三.運(yùn)行環(huán)境</b></p><p> ×VisualC++6.0帶MFC基礎(chǔ)類
22、庫,WindowsXP環(huán)境</p><p> ×Intel Pentium以上CPU、64MB以上內(nèi)存</p><p> ×推薦使用PIII以上CPU、128MB以上內(nèi)存</p><p><b> 四.算法設(shè)計(jì)的思想</b></p><p> 計(jì)算機(jī)上的非數(shù)值處理的對(duì)象基本上都是字符串?dāng)?shù)據(jù),隨
23、著語言加工程序的發(fā)展,產(chǎn)生了字符串處理的一系列的操作。本軟件所使用的基本操作和存儲(chǔ)結(jié)構(gòu)為采用串的堆分配存儲(chǔ)結(jié)構(gòu),并定義相應(yīng)的操作函數(shù)。文本編輯的操作函數(shù)調(diào)用這些方法并結(jié)合MFC的庫函數(shù)實(shí)現(xiàn)文本編輯的圖形界面。</p><p><b> 串的堆分配存儲(chǔ):</b></p><p> struct HString</p><p><b>
24、; {</b></p><p> char *ch; // 若是非空串,則按串長(zhǎng)分配存儲(chǔ)區(qū),否則ch為NULL</p><p> int length; // 串長(zhǎng)度</p><p><b> };</b></p><p> 串的堆分配存儲(chǔ)的實(shí)現(xiàn)函數(shù):</p><p> S
25、tatus StrAssign(HString &T,char *chars);</p><p> Status StrCopy(HString &T,HString S);</p><p> Status StrEmpty(HString S);</p><p> int StrCompare(HString S,HString T);<
26、;/p><p> int StrLength(HString S);</p><p> Status ClearString(HString &S);</p><p> Status Concat(HString &T,HString S1,HString S2);</p><p> Status SubString(HS
27、tring &Sub, HString S,int pos,int len);</p><p> void InitString(HString &T);</p><p> int Index(HString S,HString T,int pos) ;// 嚴(yán)蔚敏《數(shù)據(jù)結(jié)構(gòu)》算法4.1</p><p> Status StrInsert(HS
28、tring &S,int pos,HString T); // 算法4.4;</p><p> Status StrDelete(HString &S,int pos,int len);</p><p> Status Replace(HString &S,HString T,HString V);</p><p> void Dest
29、royString();</p><p> void StrPrint(HString T);</p><p> 現(xiàn)在主要分析一下Index(S,T,pos)和StrInsert的基本思想:</p><p> Index(S,T,pos):在主串S中取第i(i的初值為pos)個(gè)字符起、長(zhǎng)度和串T相等的字串和串T比較,若相等,則求出函數(shù)值為i,否則i值增1直至串
30、S中不存在和串T相等的子串為止。</p><p> StrInsert(&S,pos,T):為串S重新分配大小等于串S和串T長(zhǎng)度之和的存儲(chǔ)空間,然后進(jìn)行復(fù)制。</p><p> 文本編輯的操作函數(shù):</p><p> void Open();</p><p> char* List();</p><p>
31、; void Insert();</p><p> void Delete();</p><p> void Copy();</p><p> void Modify();</p><p> void Search();</p><p> void Replace();</p><p&g
32、t; void Save();</p><p><b> 算法的流程圖</b></p><p><b> 主程序的流程圖:</b></p><p><b> 算法設(shè)計(jì)分析</b></p><p> 本軟件所使用的基本操作和存儲(chǔ)結(jié)構(gòu)為采用串的堆分配存儲(chǔ)結(jié)構(gòu),并定義相應(yīng)的
33、操作函數(shù)。文本編輯的操作函數(shù)調(diào)用這些方法并結(jié)合MFC的庫函數(shù)實(shí)現(xiàn)文本編輯的圖形界面。</p><p><b> 串的堆分配存儲(chǔ):</b></p><p> struct HString</p><p><b> {</b></p><p> char *ch; // 若是非空串,則按串長(zhǎng)分配
34、存儲(chǔ)區(qū),否則ch為NULL</p><p> int length; // 串長(zhǎng)度</p><p><b> };</b></p><p> 串的堆分配存儲(chǔ)的主要實(shí)現(xiàn)函數(shù)分析:</p><p> Status StrCopy(HString &T,HString S)</p><p&
35、gt; { // 初始條件: 串S存在。操作結(jié)果: 由串S復(fù)制得串T</p><p><b> int i;</b></p><p><b> if(T.ch)</b></p><p> free(T.ch); // 釋放T原有空間</p><p> T.ch=(char*)malloc(
36、S.length*sizeof(char)); // 分配串空間</p><p> if(!T.ch) // 分配串空間失敗</p><p> exit(OVERFLOW);</p><p> for(i=0;i<S.length;i++) // 拷貝串</p><p> T.ch[i]=S.ch[i];</p>
37、<p> T.length=S.length;</p><p> return OK;</p><p><b> }</b></p><p> 此函數(shù)可以把一個(gè)串T釋放,然后吧串S復(fù)制到T,得到新串。時(shí)間復(fù)雜度為O(S.length);</p><p> int Index(HString S,HSt
38、ring T,int pos) // 嚴(yán)蔚敏《數(shù)據(jù)結(jié)構(gòu)》算法4.1</p><p> { // T為非空串。若主串S中第pos個(gè)字符之后存在與T相等的子串,</p><p> // 則返回第一個(gè)這樣的子串在S中的位置,否則返回0</p><p> int n,m,i;</p><p> HString sub;</p>
39、<p> InitString(sub);</p><p><b> if(pos>0)</b></p><p><b> {</b></p><p> n=StrLength(S);</p><p> m=StrLength(T);</p><p>
40、;<b> i=pos;</b></p><p> while(i<=n-m+1)</p><p><b> {</b></p><p> SubString(sub,S,i,m);</p><p> if(StrCompare(sub,T)!=0)</p><p
41、><b> ++i;</b></p><p><b> else</b></p><p><b> return i;</b></p><p><b> }</b></p><p><b> }</b></p&g
42、t;<p><b> return 0;</b></p><p><b> }</b></p><p> 利用判等、求串長(zhǎng)和求子串的操作可以實(shí)現(xiàn)求子串位置定位函數(shù)Index(HString S,HString T,int pos) ,T為非空串。若主串S中第pos個(gè)字符之后存在與T相等的子串, 則返回第一個(gè)這樣的子串在S中的位
43、置,否則返回0,時(shí)間復(fù)雜度為O( );</p><p> 文本編輯器的主要功能函數(shù)的基本操作:</p><p> #define MAX_LEN 200 // 文件最大行數(shù)</p><p> #define LINE_LEN 200 // 每行字符數(shù)最大值+1</p><p> #define NAME_LEN 50 // 文件名最大
44、長(zhǎng)度(包括盤符、路徑)+1</p><p> void Open();</p><p> char* List();</p><p> void Insert();</p><p> void Delete();</p><p> void Copy();</p><p> void
45、 Modify();</p><p> void Search();</p><p> void Replace();</p><p> void Save();</p><p> 文本編輯器的主要功能函數(shù)算法分析:</p><p> void Insert()</p><p><
46、;b> { // 插入行</b></p><p> int i,l,m;</p><p> CInsertDlg dlg; </p><p> if(IDOK==dlg.DoModal())//在第l行前插m行,請(qǐng)輸入l m:</p><p><b> {</b></p><
47、;p> l=dlg.m_insertl;</p><p> m=dlg.m_insertm;</p><p><b> }</b></p><p> if(n+m>MAX_LEN)</p><p><b> {</b></p><p> Message
48、Box(hWnd,"插入行太多\n","提示",</p><p> MB_OK|MB_ICONEXCLAMATION );</p><p><b> return;</b></p><p><b> }</b></p><p> if(n>=l-
49、1&&l>0)</p><p><b> {</b></p><p> for(i=n-1;i>=l-1;i--)</p><p> T[i+m]=T[i];</p><p><b> n+=m;</b></p><p> for(i=l
50、-1;i<l-1+m;i++)</p><p><b> {</b></p><p> CInsertInforDlg indlg;</p><p> if(IDOK==indlg.DoModal())//順序輸入待插入內(nèi)容:</p><p><b> {</b></p>
51、<p> strcpy(str,indlg.m_insertinfor.GetBuffer(0));</p><p><b> }</b></p><p> InitString(T[i]);</p><p> StrAssign(T[i],str);</p><p><b> }<
52、/b></p><p><b> }</b></p><p><b> else</b></p><p> MessageBox(hWnd,"行超出范圍\n",</p><p> "提示",MB_OK|MB_ICONEXCLAMATION );&
53、lt;/p><p><b> }</b></p><p> 上述算法是對(duì)插入行數(shù)據(jù)函數(shù)的定義,它和MFC的一些庫函數(shù)有很多的嵌套調(diào)用,需要包含很多頭文件。先調(diào)用輸入框的對(duì)話框輸入插入的起始位置,第二個(gè)輸入框是插入的總行數(shù),它可以支持插入多行。</p><p> void Replace()</p><p> { //
54、 替換字符串</p><p> int i,k,f=1,count=0; // f為繼續(xù)替換標(biāo)志</p><p> HString s,t;</p><p> CReplaceDlg dlg;</p><p> if(dlg.DoModal()==IDOK)// 輸入待替換的字符串:</p><p><b
55、> {</b></p><p> strcpy(str,dlg.m_replacey.GetBuffer(0));</p><p> strcpy(strr,dlg.m_replaceh.GetBuffer(0));</p><p><b> }</b></p><p> InitString
56、(s);</p><p> StrAssign(s,str);</p><p> InitString(t);</p><p> StrAssign(t,strr);</p><p> for(i=0;i<n&&f;i++) // 逐行查找、替換</p><p><b> {&
57、lt;/b></p><p> k=1; // 由每行第1個(gè)字符起查找</p><p><b> while(k)</b></p><p><b> {</b></p><p> k=Index(T[i],s,k); // 由本行的第k個(gè)字符開始查找</p><p&
58、gt; if(k) // 找到</p><p><b> {</b></p><p><b> count++;</b></p><p> CString strS;</p><p> strS.Format("第%d行: %s\n第%d個(gè)字符處找到。是否替換(Y/N)? &qu
59、ot;,i+1,T[i].ch,k);</p><p> if(IDYES==MessageBox(hWnd,strS,"提示",</p><p> MB_YESNO|MB_ICONQUESTION ))</p><p><b> {</b></p><p> StrDelete(T[i],k
60、,StrLength(s));</p><p> StrInsert(T[i],k,t);</p><p><b> }</b></p><p> if(IDNO==MessageBox(hWnd,"繼續(xù)替換嗎(Y/N)?\n","提示",</p><p> MB_YESN
61、O|MB_ICONQUESTION ))</p><p> {// 中斷查找、替換</p><p><b> f=0;</b></p><p><b> break;</b></p><p><b> }</b></p><p><b>
62、; else</b></p><p> k+=StrLength(t);</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> if(
63、f)</b></p><p> MessageBox(hWnd,"沒找到\n","提示",MB_OK);</p><p> CString strT;</p><p> strT.Format("共替換 %d個(gè)\n",count);</p><p> strT+=
64、dlg.m_replacey;</p><p> MessageBox(hWnd,strT,"替換結(jié)果",MB_OK|MB_ICONEXCLAMATION );</p><p><b> }</b></p><p> 上述算法是對(duì)替換數(shù)據(jù)函數(shù)的定義,它和MFC的一些庫函數(shù)有很多的嵌套調(diào)用,需要包含很多頭文件。先調(diào)用輸入
65、框的對(duì)話框輸入要被替換的字符串,第二個(gè)輸入框是輸入新字符串,它可以支持一次替換多行,甚至全部替換。</p><p><b> 源代碼</b></p><p> 以下為自己添加的頭文件程序:</p><p> // c1.h (程序名)</p><p> #include<string.h></p
66、><p> #include<ctype.h></p><p> #include<malloc.h> // malloc()等</p><p> #include<limits.h> // INT_MAX等</p><p> #include<stdio.h> // EOF(=^Z或F6)
67、,NULL</p><p> #include<stdlib.h> // atoi()</p><p> #include<io.h> // eof()</p><p> #include<math.h> // floor(),ceil(),abs()</p><p> #include<pr
68、ocess.h> // exit()</p><p> #include<iostream.h> // cout,cin</p><p> // 函數(shù)結(jié)果狀態(tài)代碼</p><p> #define TRUE 1</p><p> #define FALSE 0</p><p> #defin
69、e OK 1</p><p> #define ERROR 0</p><p> #define INFEASIBLE -1</p><p> // #define OVERFLOW -2 因?yàn)樵趍ath.h中已定義OVERFLOW的值為3,故去掉此行</p><p> typedef int Status; // Status是函數(shù)
70、的類型,其值是函數(shù)結(jié)果狀態(tài)代碼,如OK等</p><p> typedef int Boolean; // Boolean是布爾類型,其值是TRUE或FALSE</p><p> // c4-2.h 串的堆分配存儲(chǔ)</p><p> struct HString</p><p><b> {</b></p&
71、gt;<p> char *ch; // 若是非空串,則按串長(zhǎng)分配存儲(chǔ)區(qū),否則ch為NULL</p><p> int length; // 串長(zhǎng)度</p><p><b> };</b></p><p> Status StrAssign(HString &T,char *chars);</p>&
72、lt;p> Status StrCopy(HString &T,HString S);</p><p> Status StrEmpty(HString S);</p><p> int StrCompare(HString S,HString T);</p><p> int StrLength(HString S);</p>
73、<p> Status ClearString(HString &S);</p><p> Status Concat(HString &T,HString S1,HString S2);</p><p> Status SubString(HString &Sub, HString S,int pos,int len);</p>&l
74、t;p> void InitString(HString &T);</p><p> int Index(HString S,HString T,int pos) ;// 算法4.1</p><p> Status StrInsert(HString &S,int pos,HString T); // 嚴(yán)蔚敏《數(shù)據(jù)結(jié)構(gòu)》算法4.4;</p><
75、;p> Status StrDelete(HString &S,int pos,int len);</p><p> Status Replace(HString &S,HString T,HString V);</p><p> void DestroyString();</p><p> void StrPrint(HString
76、T);</p><p> //textedit.h 文本行編輯</p><p> #include"c1.h"</p><p> #include"c4_2.h" // 采用串的堆分配存儲(chǔ)結(jié)構(gòu),包含串的堆分配基本操作</p><p> #define MAX_LEN 200 // 文件最大行數(shù)&
77、lt;/p><p> #define LINE_LEN 200 // 每行字符數(shù)最大值+1</p><p> #define NAME_LEN 50 // 文件名最大長(zhǎng)度(包括盤符、路徑)+1</p><p> void Open();</p><p> char* List();</p><p> void I
78、nsert();</p><p> void Delete();</p><p> void Copy();</p><p> void Modify();</p><p> void Search();</p><p> void Replace();</p><p> void
79、Save();</p><p> 以下為自己添加的源文件程序(即各種函數(shù)的實(shí)現(xiàn)部分):</p><p> //c4_2.cpp文件</p><p> #include"StdAfx.h"</p><p> #include"c4_2.h"</p><p> Status
80、 StrAssign(HString &T,char *chars)</p><p> { // 生成一個(gè)其值等于串常量chars的串T</p><p><b> int i,j;</b></p><p><b> if(T.ch)</b></p><p> free(T.ch);
81、// 釋放T原有空間</p><p> i=strlen(chars); // 求chars的長(zhǎng)度i</p><p><b> if(!i)</b></p><p> { // chars的長(zhǎng)度為0</p><p> T.ch=NULL;</p><p> T.length=0;<
82、/p><p><b> }</b></p><p><b> else</b></p><p> { // chars的長(zhǎng)度不為0</p><p> T.ch=(char*)malloc(i*sizeof(char)); // 分配串空間</p><p> if(!T.
83、ch) // 分配串空間失敗</p><p> exit(OVERFLOW);</p><p> for(j=0;j<i;j++) // 拷貝串</p><p> T.ch[j]=chars[j];</p><p> T.length=i;</p><p><b> }</b>&l
84、t;/p><p> return OK;</p><p><b> }</b></p><p> Status StrCopy(HString &T,HString S)</p><p> { // 初始條件: 串S存在。操作結(jié)果: 由串S復(fù)制得串T</p><p><b>
85、 int i;</b></p><p><b> if(T.ch)</b></p><p> free(T.ch); // 釋放T原有空間</p><p> T.ch=(char*)malloc(S.length*sizeof(char)); // 分配串空間</p><p> if(!T.ch)
86、// 分配串空間失敗</p><p> exit(OVERFLOW);</p><p> for(i=0;i<S.length;i++) // 拷貝串</p><p> T.ch[i]=S.ch[i];</p><p> T.length=S.length;</p><p> return OK;<
87、;/p><p><b> }</b></p><p> Status StrEmpty(HString S)</p><p> { // 初始條件: 串S存在。操作結(jié)果: 若S為空串,則返回TRUE,否則返回FALSE</p><p> if(S.length==0&&S.ch==NULL)</
88、p><p> return TRUE;</p><p><b> else</b></p><p> return FALSE;</p><p><b> }</b></p><p> int StrCompare(HString S,HString T)</p&
89、gt;<p> { // 若S>T,則返回值>0;若S=T,則返回值=0;若S<T,則返回值<0</p><p><b> int i;</b></p><p> for(i=0;i<S.length&&i<T.length;++i)</p><p> if(S.ch[i
90、]!=T.ch[i])</p><p> return S.ch[i]-T.ch[i];</p><p> return S.length-T.length;</p><p><b> }</b></p><p> int StrLength(HString S)</p><p> {
91、// 返回S的元素個(gè)數(shù),稱為串的長(zhǎng)度</p><p> return S.length;</p><p><b> }</b></p><p> Status ClearString(HString &S)</p><p> { // 將S清為空串</p><p><b>
92、; if(S.ch)</b></p><p><b> {</b></p><p> free(S.ch);</p><p> S.ch=NULL;</p><p><b> }</b></p><p> S.length=0;</p>
93、<p> return OK;</p><p><b> }</b></p><p> Status Concat(HString &T,HString S1,HString S2)</p><p> { // 用T返回由S1和S2聯(lián)接而成的新串</p><p><b> int i
94、;</b></p><p><b> if(T.ch)</b></p><p> free(T.ch); // 釋放舊空間</p><p> T.length=S1.length+S2.length;</p><p> T.ch=(char *)malloc(T.length*sizeof(char)
95、);</p><p><b> if(!T.ch)</b></p><p> exit(OVERFLOW);</p><p> for(i=0;i<S1.length;i++)</p><p> T.ch[i]=S1.ch[i];</p><p> for(i=0;i<S2.
96、length;i++)</p><p> T.ch[S1.length+i]=S2.ch[i];</p><p> return OK;</p><p><b> }</b></p><p> Status SubString(HString &Sub, HString S,int pos,int len
97、)</p><p> { // 用Sub返回串S的第pos個(gè)字符起長(zhǎng)度為len的子串。</p><p> // 其中,1≤pos≤StrLength(S)且0≤len≤StrLength(S)-pos+1</p><p><b> int i;</b></p><p> if(pos<1||pos>S
98、.length||len<0||len>S.length-pos+1)</p><p> return ERROR;</p><p> if(Sub.ch)</p><p> free(Sub.ch); // 釋放舊空間</p><p> if(!len) // 空子串</p><p><b&
99、gt; {</b></p><p> Sub.ch=NULL;</p><p> Sub.length=0;</p><p><b> }</b></p><p><b> else</b></p><p><b> { // 完整子串<
100、;/b></p><p> Sub.ch=(char*)malloc(len*sizeof(char));</p><p> if(!Sub.ch)</p><p> exit(OVERFLOW);</p><p> for(i=0;i<=len-1;i++)</p><p> Sub.ch[i]
101、=S.ch[pos-1+i];</p><p> Sub.length=len;</p><p><b> }</b></p><p> return OK;</p><p><b> }</b></p><p> void InitString(HString &
102、amp;T)</p><p> { // 初始化(產(chǎn)生空串)字符串T。另加</p><p> T.length=0;</p><p> T.ch=NULL;</p><p><b> }</b></p><p> int Index(HString S,HString T,int pos
103、) // 算法4.1</p><p> { // T為非空串。若主串S中第pos個(gè)字符之后存在與T相等的子串,</p><p> // 則返回第一個(gè)這樣的子串在S中的位置,否則返回0</p><p> int n,m,i;</p><p> HString sub;</p><p> InitString(s
104、ub);</p><p><b> if(pos>0)</b></p><p><b> {</b></p><p> n=StrLength(S);</p><p> m=StrLength(T);</p><p><b> i=pos;</
105、b></p><p> while(i<=n-m+1)</p><p><b> {</b></p><p> SubString(sub,S,i,m);</p><p> if(StrCompare(sub,T)!=0)</p><p><b> ++i;<
106、/b></p><p><b> else</b></p><p><b> return i;</b></p><p><b> }</b></p><p><b> }</b></p><p><b>
107、 return 0;</b></p><p><b> }</b></p><p> Status StrInsert(HString &S,int pos,HString T) // 算法4.4</p><p> { // 1≤pos≤StrLength(S)+1。在串S的第pos個(gè)字符之前插入串T</p>
108、;<p><b> int i;</b></p><p> if(pos<1||pos>S.length+1) // pos不合法</p><p> return ERROR;</p><p> if(T.length) // T非空,則重新分配空間,插入T</p><p><b&
109、gt; {</b></p><p> S.ch=(char*)realloc(S.ch,(S.length+T.length)*sizeof(char));</p><p><b> if(!S.ch)</b></p><p> exit(OVERFLOW);</p><p> for(i=S.le
110、ngth-1;i>=pos-1;--i) // 為插入T而騰出位置</p><p> S.ch[i+T.length]=S.ch[i];</p><p> for(i=0;i<T.length;i++)</p><p> S.ch[pos-1+i]=T.ch[i]; // 插入T</p><p> S.length+=T.
111、length;</p><p><b> }</b></p><p> return OK;</p><p><b> }</b></p><p> Status StrDelete(HString &S,int pos,int len)</p><p>
112、{ // 從串S中刪除第pos個(gè)字符起長(zhǎng)度為len的子串</p><p><b> int i;</b></p><p> if(S.length<pos+len-1)</p><p> exit(ERROR);</p><p> for(i=pos-1;i<=S.length-len;i++)<
113、;/p><p> S.ch[i]=S.ch[i+len];</p><p> S.length-=len;</p><p> S.ch=(char*)realloc(S.ch,S.length*sizeof(char));</p><p> return OK;</p><p><b> }</b
114、></p><p> Status Replace(HString &S,HString T,HString V)</p><p> { // 初始條件: 串S,T和V存在,T是非空串(此函數(shù)與串的存儲(chǔ)結(jié)構(gòu)無關(guān))</p><p> // 操作結(jié)果: 用V替換主串S中出現(xiàn)的所有與T相等的不重疊的子串</p><p> in
115、t i=1; // 從串S的第一個(gè)字符起查找串T</p><p> if(StrEmpty(T)) // T是空串</p><p> return ERROR;</p><p><b> do</b></p><p><b> {</b></p><p> i=In
116、dex(S,T,i); // 結(jié)果i為從上一個(gè)i之后找到的子串T的位置</p><p> if(i) // 串S中存在串T</p><p><b> {</b></p><p> StrDelete(S,i,StrLength(T)); // 刪除該串T</p><p> StrInsert(S,i,V); //
117、 在原串T的位置插入串V</p><p> i+=StrLength(V); // 在插入的串V后面繼續(xù)查找串T</p><p><b> }</b></p><p> }while(i);</p><p> return OK;</p><p><b> }</b>
118、;</p><p> void DestroyString()</p><p> { // 堆分配類型的字符串無法銷毀</p><p><b> }</b></p><p> void StrPrint(HString T)</p><p> { // 輸出T字符串。另加</p&g
119、t;<p><b> int i;</b></p><p> for(i=0;i<T.length;i++)</p><p> printf("%c",T.ch[i]);</p><p> printf("\n");</p><p><b>
120、 }</b></p><p> //textedit.cpp// algo4-3.cpp 文本行編輯</p><p> #include"StdAfx.h"</p><p> #include "kecheng.h"</p><p> #include "openDlg.h
121、"</p><p> #include "InsertDlg.h"</p><p> #include "InsertInforDlg.h"</p><p> #include "DeleteDlg.h"</p><p> #include "CopyDl
122、g.h"</p><p> #include "ModifyDlg.h"</p><p> #include "ModifyInforDlg.h"</p><p> #include "SearchDlg.h"</p><p> #include "Rep
123、laceDlg.h"</p><p> #include "windows.h"</p><p> #include"textedit.h"</p><p> #include"c1.h"</p><p> #include"c4_2.h" //
124、 采用串的堆分配存儲(chǔ)結(jié)構(gòu)</p><p> #define MAX_LEN 200 // 文件最大行數(shù)</p><p> #define LINE_LEN 200 // 每行字符數(shù)最大值+1</p><p> #define NAME_LEN 50 // 文件名最大長(zhǎng)度(包括盤符、路徑)+1</p><p><b> //
125、全局變量</b></p><p> HString T[MAX_LEN];</p><p> char str[LINE_LEN],strr[LINE_LEN],filename[NAME_LEN]="";</p><p><b> FILE *fp;</b></p><p> i
126、nt n=0; // 文件行數(shù)</p><p> HWND hWnd;</p><p> void Open()</p><p> { // 打開文件(新或舊)</p><p><b> int i;</b></p><p> if(filename[0]) // 文件已打開</p
127、><p> MessageBox(hWnd,"已存在打開的文件\n","提示",</p><p> MB_OK|MB_ICONINFORMATION );</p><p><b> else</b></p><p><b> {</b></p>
128、<p> CopenDlg dlg;</p><p> if(IDOK==dlg.DoModal())</p><p><b> {</b></p><p> //filename=dlg.m_filename;</p><p> strcpy((char*)filename,dlg.m_file
129、name.GetBuffer(0));//strcpy拷貝字符串,遇到'\0'就結(jié)束拷貝;</p><p><b> }</b></p><p> else return;//取消操作 返回void值</p><p> fp=fopen(filename,"r");</p><p&g
130、t; if(fp) // 已存在此文件</p><p><b> {</b></p><p><b> do</b></p><p><b> {</b></p><p> fgets(str,LINE_LEN,fp);</p><p> i
131、=strlen(str);</p><p> str[i-1]=0; // 將10強(qiáng)制改為0</p><p><b> i--;</b></p><p><b> if(i>0)</b></p><p><b> {</b></p><p>
132、; StrAssign(T[n],str);</p><p><b> n++;</b></p><p> if(n>MAX_LEN)</p><p><b> {</b></p><p> MessageBox(hWnd,"文件太大\n","提示&qu
133、ot;,</p><p> MB_OK|MB_ICONEXCLAMATION );</p><p><b> return;</b></p><p><b> }</b></p><p><b> }</b></p><p> }while(i
134、>0);</p><p> fclose(fp);</p><p><b> }</b></p><p><b> else</b></p><p> MessageBox(hWnd,"新文件\n","提示",</p><p
135、> MB_OK|MB_ICONEXCLAMATION );</p><p><b> }</b></p><p><b> }</b></p><p> char* List()</p><p> { // 顯示文件內(nèi)容</p><p><b>
136、int i;</b></p><p> CString strT,strS;</p><p> for(i=0;i<n;i++)</p><p><b> { </b></p><p> strT.Format("%d:%s",i+1,T[i].ch);//格式化函數(shù)1 s
137、trT.Format("%d:%s",i+1,T[i].ch);</p><p> //printf("%d: ",i+1);//函數(shù)2為sprintf(tempf,"%s說:%s",chara,charb);其中tempf[80],chara[10],charb[10]為char</p><p> strS+=strT;
138、</p><p> strS+="\r\n";</p><p><b> }</b></p><p> getchar();</p><p> char str1[32678];</p><p> strcpy(str1,strS.GetBuffer(0));<
溫馨提示
- 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. 眾賞文庫僅提供信息存儲(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)課程設(shè)計(jì)--文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---簡(jiǎn)易文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--簡(jiǎn)易文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-簡(jiǎn)易文本編輯器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-小型文本編輯器的設(shè)計(jì)
- 文本編輯器課程設(shè)計(jì)報(bào)告
- 文本編輯器課程設(shè)計(jì)
- 簡(jiǎn)易文本編輯器課程設(shè)計(jì)報(bào)告
- vb課程設(shè)計(jì)報(bào)告----文本編輯器
- vb課程設(shè)計(jì)報(bào)告---文本編輯器
- java課程設(shè)計(jì)--文本編輯器
- java課程設(shè)計(jì)---文本編輯器
- java課程設(shè)計(jì)---文本編輯器
- vb課程設(shè)計(jì)文本編輯器
- java課程設(shè)計(jì)(文本編輯器)
- c語言課程設(shè)計(jì)--文本編輯器
- c_文本編輯器課程設(shè)計(jì)
- 文本編輯器_java課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
- visual_basic課程設(shè)計(jì)報(bào)告---文本編輯器
- 操作系統(tǒng)課程設(shè)計(jì)---文本編輯器
評(píng)論
0/150
提交評(píng)論