版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計——串的查找與替換</p><p><b> 問題陳述:</b></p><p><b> 需求分析:</b></p><p> 概要設(shè)計和詳細設(shè)計:</p><p><b> 程序代碼:</b></p><p&
2、gt;<b> 結(jié)果與測試:</b></p><p><b> 六、體會與總結(jié):</b></p><p><b> 一、問題陳述:</b></p><p> 打開一篇英文文章,在該文章中找出所有給定的單詞,然后對所有給定的單詞替換為另外一個單詞,再存盤。</p><p>
3、;<b> 設(shè)計要求:</b></p><p> (1) 符合課題要求,實現(xiàn)相應(yīng)功能;</p><p> (2) 操作方便易行;</p><p> (3) 注意程序的實用性、安全性;</p><p><b> 二、需求分析:</b></p><p> 串的查找與替
4、換要實現(xiàn)的功能是:打開一篇英文文章,在該文章中找出所有給定的單詞,然后對所有給定的單詞替換為另外一個單詞,再存盤。</p><p> 首先實現(xiàn)程序比較簡單的功能,即:輸入要替換的單詞和給定單詞gets(keyWords); gets(copyWords)。</p><p> 然后實現(xiàn)程序打開文件的功能。</p><p> 最后編寫最核心的替換功能,首先用關(guān)鍵字
5、來匹配要查找的單詞,第一個單詞匹配上的話再判斷這個關(guān)鍵字在不在單詞的首字母上,否則不匹配,主要是要實現(xiàn)替換單詞的功能不替換其他單詞中的字符串。然后匹配第二個字母,這樣一次類推的判斷。不匹配的單詞直接放入strTwo數(shù)組中,匹配的單詞先替換然后再放入strTwo數(shù)組中。</p><p> 三、概要設(shè)計和詳細設(shè)計:</p><p><b> 程序頭設(shè)計</b><
6、/p><p> 對程序作簡單介紹以及輸出程序制作人的基本信息。</p><p><b> main()</b></p><p><b> {</b></p><p> printf("\n\n\n\t\t\t數(shù)據(jù)結(jié)構(gòu)課程設(shè)計\n");</p><p>
7、 printf("\n\t\t\t題目:串的查找與替換\n");</p><p> printf("\n\t\t\t專業(yè):信息管理與信息系統(tǒng)\n");</p><p> printf("\n\t\t\t學(xué)號:2013143129\n");</p><p> printf("\n\t\t\t
8、姓名:張朝翔");</p><p> printf("\n\t程序作用:打開一篇英語作文,在該文章中找出所有給定的單詞,然后對\n\t所有給定的單詞替換為另一個單詞再存盤。");</p><p> printf("\n************************************\n");</p><p&g
9、t;<b> }</b></p><p> 主函數(shù)void main()</p><p> 通過for循環(huán)對字符串進行匹配,找到匹配的單詞然后將copy的單詞字符放入strTwo數(shù)組中,不匹配的單詞也放入數(shù)組strTwo中完成替換,最后把strTwo中的字符放回文件中完成操作。</p><p><b> 5.程序代碼:<
10、/b></p><p> #include <stdio.h></p><p> #include <stdlib.h></p><p> #define SIZE 20 /* 查找單詞字符和輸入替換單詞少于20 */</p><p> #define MAXLEN 10000
11、 /* 文章字符不大于10000 */</p><p> void main()</p><p><b> {</b></p><p><b> int i, j;</b></p><p> int flag; /* 用于標(biāo)記匹配單詞 */</p&g
12、t;<p> int countFlag; /* 用于檢查匹配計數(shù) */</p><p> int countOne = 0; /* 記錄未改文章字符個數(shù) */</p><p> int countTwo = 0; /* 記錄改后文章字符個數(shù) */</p><p> char keyWords[SIZE];
13、 /* 查找單詞 */</p><p> char copyWords[SIZE];/* 替換單詞 */</p><p> char strOne[MAXLEN]; /* 將未改文章的所有字符儲存在里面 */</p><p> char strTwo[MAXLEN]; /* 將改后文章的所有字符儲存在里面 */</p><p
14、> char filename[20]; /*輸入的文件名的字符個數(shù)*/</p><p><b> {</b></p><p> printf("\n\n\n\t\t\t數(shù)據(jù)結(jié)構(gòu)課程設(shè)計\n");</p><p> printf("\n\t\t\t題目:串的查找與替換\n");</
15、p><p> printf("\n\t\t\t專業(yè):信息管理與信息系統(tǒng)\n");</p><p> printf("\n\t\t\t學(xué)號:2013143129\n");</p><p> printf("\n\t\t\t姓名:張朝翔");</p><p> printf(&quo
16、t;\n\t程序作用:打開一篇英語作文,在該文章中找出所有給定的單詞,然后對\n\t所有給定的單詞替換為另一個單詞再存盤。");</p><p> printf("\n******************************************************************************\n");</p><p><
17、b> }</b></p><p><b> FILE *fp;</b></p><p> printf("請輸入要查找的單詞: ");</p><p> gets(keyWords);</p><p> printf("請輸入要替換的單詞: ");<
18、;/p><p> gets(copyWords);</p><p> printf("請輸入要打開的文件名:");</p><p> scanf("%s",filename);</p><p> if ((fp = fopen(filename, "r")) ==NULL )/*
19、 讀文件,前邊的就是輸入的文件名,后邊是指只讀read */</p><p><b> {</b></p><p> printf("文件打開失敗!\n");</p><p><b> exit(0);</b></p><p><b> }</b>
20、;</p><p> while (!feof(fp))/* 讀文件 */</p><p><b> {</b></p><p> strOne[countOne++] = fgetc(fp);/*這是從指定穩(wěn)中取得一個字符 strOne[countOne++] = fgets(fp);這是從指定文章中取得一個字符串*/</p&
21、gt;<p><b> }</b></p><p> countOne--;/* 減去最后一個文件結(jié)束字符 */</p><p> for (i=0; i<countOne; i++)</p><p><b> {</b></p><p> if (keyWords
22、[0] == strOne[i])/* 判斷查找單詞第一個字符是否匹配 */</p><p><b> {</b></p><p> if ((' ' == strOne[i-1]) || ('\n' == strOne[i-1]) || (0 == i))/* 1.檢查單詞前的一個字符 */</p><
23、p><b> {</b></p><p><b> flag = 1;</b></p><p> countFlag = i + 1;</p><p> for (j=1; keyWords[j]!='\0'; j++)</p><p><b> { <
24、;/b></p><p> if (keyWords[j] != strOne[countFlag++])/* 是否匹配 */</p><p><b> { </b></p><p><b> flag = 0;</b></p><p><b> break;</b
25、></p><p><b> } </b></p><p><b> }</b></p><p> if ((' ' == strOne[countFlag]) || ('\n' == strOne[countFlag]) || (EOF == strOne[countFlag]
26、))/* 2.檢查單詞后的一個字符 */</p><p><b> {</b></p><p> if (1 == flag)/* 若匹配,則進行拷貝 */</p><p><b> { </b></p><p> i = countFlag-1;</p><
27、p> for (j=0; copyWords[j]!='\0'; j++)</p><p><b> { </b></p><p> strTwo[countTwo++] = copyWords[j]; </p><p><b> } </b></p><p>
28、<b> } </b></p><p><b> }</b></p><p> else/* 另外 */</p><p><b> {</b></p><p> strTwo[countTwo++] = strOne[i];</p><p&g
29、t;<b> }</b></p><p><b> }</b></p><p> else/* 另外 */</p><p><b> {</b></p><p> strTwo[countTwo++] = strOne[i];</p><p&g
30、t;<b> }</b></p><p><b> }</b></p><p> else/* 另外 */</p><p><b> {</b></p><p> strTwo[countTwo++] = strOne[i];</p><p&g
31、t;<b> } </b></p><p><b> }</b></p><p> fclose(fp);</p><p> if ((fp = fopen("filename", "w")) ==NULL )/* 寫入文件 */</p><p>
32、<b> {</b></p><p> printf("文件打開失敗!\n");</p><p><b> exit(1);</b></p><p><b> }</b></p><p> for (i=0; i<countTwo; i++)
33、/* 寫入文件 */</p><p><b> {</b></p><p> fputc(strTwo[i], fp);</p><p><b> }</b></p><p> fclose(fp);</p><p><b> }</b>&
34、lt;/p><p><b> 五、結(jié)果與測試:</b></p><p> 圖1 程序開始的界面</p><p> 圖2 輸入要查找和替換的單詞</p><p> 圖3 輸入要打開的文件名</p><p><b> 六、體會與總結(jié):</b></p><
溫馨提示
- 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)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 匯編課程設(shè)計-字符串查找與替換
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--字符串的操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計----huffman編碼
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計實驗報告---有關(guān)查找的操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--汽車牌照的快速查找
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--基于線性表下的查找與排序
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--數(shù)據(jù)結(jié)構(gòu)的實現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--兩種常用查找算法的比較與實現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)及其應(yīng)用(算法與數(shù)據(jù)結(jié)構(gòu)課程設(shè)計)
評論
0/150
提交評論