版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> C語言課程設(shè)計(jì)</b></p><p> 題目編號和名稱 簡單的行編輯器 </p><p> 教師姓名 </p><p> 學(xué)生姓名
2、 </p><p> 學(xué)生學(xué)號 </p><p> 學(xué)生班級 </p><p> 所在院系
3、 </p><p> 日期 2011 年 6 月 日</p><p><b> 1.【題目要求】</b></p><p> 設(shè)計(jì)一個(gè)簡單的行編輯器 </p><p><b> 【要求】 </b></p><p>
4、(1) 設(shè)置一個(gè)簡單的行編輯器,每行以回車結(jié)束 </p><p> ?。?) 數(shù)據(jù)以文件形式存儲 </p><p> (3) 編輯器具有查找、替換、修改數(shù)據(jù)的功能</p><p><b> 2.【需求分析】</b></p><p> 根據(jù)題目要求,行編輯器的數(shù)據(jù)以文本文件存放在文件中,故需要提供文件的輸入、輸出等操
5、作;在程序運(yùn)行過程中要實(shí)現(xiàn)查找、替換、修改數(shù)據(jù)的功能應(yīng)提供查找、替換、修改數(shù)據(jù)等操作;另外還應(yīng)提供鍵盤式選擇菜單功能選擇。</p><p><b> 3.【總體設(shè)計(jì)】</b></p><p> 根據(jù)上面的需求分析,可以將這一系統(tǒng)的設(shè)計(jì)分為輸入、查找、替換修改數(shù)據(jù)、退出等四個(gè)模塊(系統(tǒng)功能模塊如圖1所示)</p><p> 圖1 行編輯器
6、功能模塊圖</p><p><b> 4.【詳細(xì)設(shè)計(jì)】</b></p><p><b> 主函數(shù)</b></p><p> 主函數(shù)的設(shè)計(jì)一般較簡單,一般只提供輸入、功能處理和輸出部分的函數(shù)調(diào)用其中各功能模塊用菜單方式選擇。主函數(shù)流程圖如圖1-1 程序如下</p><p> void main
7、()</p><p><b> {</b></p><p> cout<<"\t\t\t 簡單行編輯.\n";</p><p><b> Str s1;</b></p><p><b> Str s2; </b></p>
8、<p><b> Str ss;</b></p><p><b> Str ss1;</b></p><p><b> Str ss2;</b></p><p><b> int n;</b></p><p> s1.input_st
9、r();</p><p> int choice=-1;</p><p> while(choice!=0) 圖1-1 行編輯器主函數(shù)流程</p><p><b> {</b></p><p> //system("cls");&l
10、t;/p><p> cout<<"\t\t\t *******簡單行編輯******\n";</p><p> cout<<"\t\t\t ***********************\n";</p><p> cout<<"\t\t\t 1: 打印字符串.\n&quo
11、t;;</p><p> cout<<"\t\t\t 2: 插入字符串.\n";</p><p> cout<<"\t\t\t 3: 刪除字符串.\n";</p><p> cout<<"\t\t\t 4: 復(fù)制整個(gè)字符串.\n";</p>
12、<p> cout<<"\t\t\t 5: 替換字符串.\n";</p><p> cout<<"\t\t\t 6: 查找一個(gè)字符串的位置.\n";</p><p> cout<<"\t\t\t 7: 繼續(xù)輸入. \n";</p><p>
13、 cout<<"\t\t\t 0: 退出.\n";</p><p> cout<<"\t\t\t ************************\n";</p><p> cout<<"\t\t\t 請選擇 : ";</p><p> cin>&g
14、t;choice;</p><p> switch(choice)</p><p><b> {</b></p><p> case 1: cout<<"\t\t\t1: 打印出字符串.\n";</p><p> s1.print_str(s1);</p><
15、p><b> break;</b></p><p> case 2: cout<<"\t\t\t2: 插入字符串.\n";</p><p> s1.insert_str(s1,s2,ss);</p><p><b> break;</b></p><p&g
16、t; case 3: cout<<"\t\t\t3: 刪除字符串.\n";</p><p> s1.delete_str(s1,s2);</p><p><b> break;</b></p><p> case 4: cout<<"\t\t\t4: 復(fù)制整個(gè)字符串.\n&quo
17、t;;</p><p> s1.copy_str(s1,s2);</p><p><b> break;</b></p><p> /*case 5: cout<<"\t\t\t5: 替換字符串.\n";</p><p> s1.instead_str(s1,s2,ss1,ss
18、2,n);</p><p><b> break;*/</b></p><p> case 6: cout<<"\t\t\t6: 查找一個(gè)字符串的位置.\n";</p><p> s1.find_position(s1,ss,n);</p><p><b> break
19、;</b></p><p> case 7: cout<<"\t\t\t7: 繼續(xù)輸入.\n";</p><p> s1.go_on_input(s1);</p><p><b> break;</b></p><p> case 0: cout<<&qu
20、ot;\t\t\t0: 退出.\n";</p><p><b> break;</b></p><p> default:cout<<"\t\t\terror.\n";</p><p><b> break;</b></p><p><b>
21、; }</b></p><p><b> }</b></p><p><b> }</b></p><p> 2.各功能模塊的設(shè)計(jì)</p><p> ?。?)輸入、打印模塊</p><p> 該程序需要輸入一段字符串作為其待處理數(shù)據(jù),所以通過鍵盤輸入字符
22、串作為待處理數(shù)據(jù),以回車進(jìn)入主函數(shù)界面。選擇菜單1打印出該段字符串。其程序如下,程序運(yùn)行截圖如圖2-1 2-2</p><p> void Str::input_str()</p><p><b> { </b></p><p> cout<<"\t\t\t 請輸入字符串以#結(jié)束:";</p&g
23、t;<p><b> int k;</b></p><p><b> k=0; </b></p><p> ch[k]='x'; </p><p> while( cin>>ch[k],ch[k]!='#' ) k++;</p><p&
24、gt; ch[k]='#';</p><p><b> len=k;</b></p><p><b> }</b></p><p> //下面的程序?yàn)椋猴@示整個(gè)字符串。</p><p> void Str::print_str(Str &s1)</p>
25、<p><b> {</b></p><p> cout<<"\n\t\t\t整個(gè)字符串為:";</p><p> for(int k=0;s1.ch[k]!='#';k++)</p><p> cout<<ch[k];</p><p>
26、cout<<"\n\n";</p><p><b> }</b></p><p><b> 圖2-1</b></p><p><b> 圖2-2</b></p><p><b> (2)數(shù)據(jù)修改模塊</b></
27、p><p> 該功能可通過數(shù)據(jù)插入與數(shù)據(jù)修改兩部分完成對數(shù)據(jù)的修改。1】插入 完成插入操作時(shí) 須先輸入要插入的位置,然后輸入所要插入的字符串,以‘#’結(jié)束,回車完成插入其程序如下,運(yùn)行截圖如圖2-3</p><p> void Str::insert_str(Str &s,Str s2,Str ss)</p><p><b> { <
28、;/b></p><p> cout<<"\t\t\t輸入你要插入的位置:";</p><p><b> int i;</b></p><p><b> cin>>i;</b></p><p><b> i--;</b>
29、</p><p> if(i>s.len) </p><p> cout<<"\t\t\t 插入位置不存在.\n";</p><p><b> else {</b></p><p> cout<<"\t\t\t 輸入你要插入的字符串以#結(jié)束:"
30、;</p><p><b> int r; </b></p><p><b> r=0; </b></p><p> ss.ch[r]='x';</p><p> while( cin>>ss.ch[r],ss.ch[r]!='#' ) r++
31、; </p><p> ss.ch[r]='#';</p><p><b> ss.len=r;</b></p><p> if(ss.len>MaxSize|| ( s.len +ss.len )>MaxSize)</p><p> cout<<"\t\t\t插
32、入字符串大于最大值無法插入.\n";</p><p><b> else {</b></p><p><b> int p=0;</b></p><p> for (int k=0; k<=i; k++)</p><p><b> { </b><
33、;/p><p> s2.ch[p]=s.ch[k];</p><p><b> p++;</b></p><p><b> }</b></p><p> for(k=0;k<ss.len;k++)</p><p><b> { </b>&
34、lt;/p><p> s2.ch[p]=ss.ch[k]; </p><p><b> p++;</b></p><p><b> }</b></p><p> for(k=i+1;k<s.len;k++)</p><p><b> {</b&g
35、t;</p><p> s2.ch[p]=s.ch[k];</p><p><b> p++;</b></p><p><b> }</b></p><p> s2.len=p; cout<<"\t\t\t 新字符串的長度為"<<s2.len;
36、</p><p> s2.ch[p]='#'; </p><p> for(int q=0; s2.ch[q]!='#'; q++)</p><p> s.ch[q]=s2.ch[q];</p><p> s.ch[q]='#';</p><p> s.len
37、=s2.len ;</p><p> cout <<"插入成功.\n";</p><p> print_str(s);</p><p><b> }</b></p><p><b> }</b></p><p><b> }
38、</b></p><p><b> 圖2-3</b></p><p> 2】刪除 刪除操作是作為修改模塊的一部分,同插入操作共同完成修改數(shù)據(jù)的功能。進(jìn)行刪除操作時(shí),輸入想從字符串上開始刪除的位置,再輸入刪除的字符串長度?;剀嚰纯赏瓿蓜h除。其程序如下,運(yùn)行截圖如圖2-4</p><p> void Str::delete_st
39、r(Str &s1,Str s)</p><p><b> { </b></p><p> cout<<"\t\t\t 輸入你要開始刪除的位置:";</p><p><b> int i;</b></p><p><b> cin>&g
40、t;i; </b></p><p> if(i>s1.len) cout<<"\t\t\t 太大無法刪除.\n";</p><p><b> else </b></p><p><b> { </b></p><p> cout<<
41、;"\t\t\t 輸入你要?jiǎng)h除的長度:";</p><p><b> int j;</b></p><p><b> cin>>j; </b></p><p> if(i+j>s1.len) </p><p> cout<<"\
42、t\t\t 刪除的太長無法刪除.\n";</p><p><b> else { </b></p><p><b> int p=0;</b></p><p> for (int k=0;k<i;k++)</p><p><b> {</b></p
43、><p> s.ch[p]=s1.ch[k];</p><p><b> p++;</b></p><p><b> }</b></p><p> for (k=i+j;k<s1.len;k++)</p><p><b> {</b><
44、/p><p> s.ch[p]=s1.ch[k];</p><p><b> p++;</b></p><p><b> }</b></p><p> s.len=p+1;</p><p> s.ch[p+1]='#';</p><p
45、> for(int q=0; s.ch[q]!='#'; q++)</p><p> s1.ch[q]=s.ch[q];</p><p> s1.ch[q-1]='#';</p><p> s1.len=s.len-1;</p><p> cout<<"\t\t\t 刪除成
46、功.\n";</p><p> s1.print_str(s1);</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> 圖2-4<
47、/b></p><p><b> ?。?)查找模塊</b></p><p> 在字符串內(nèi)尋找你想要的一段字符串,顯示找到的位置。選擇查找功能的菜單,通過鍵盤輸入所要查找字符串,回車即可找出其所在位置。程序如下,運(yùn)行截圖如圖2-5</p><p> void Str::find_position(Str &s,Str &
48、ss,int &n)</p><p><b> {</b></p><p> cout<<"\t\t\t 輸入字符串:";</p><p> ss.input_str(); </p><p> int y=0; </p><p> for(i
49、nt i=0;i<s.len;i++)</p><p><b> { </b></p><p> for(int j=i,k=0; s.ch[j]==ss.ch[k]; j++,k++)</p><p><b> { </b></p><p> if(k==ss.len-1)&l
50、t;/p><p> { cout<<"\t\t\t 位置是 "<<i+1<< " .\n";</p><p> position[y]=i+1; </p><p><b> y++;</b></p><p><b> }&l
51、t;/b></p><p><b> }</b></p><p><b> }</b></p><p><b> if(!y) </b></p><p><b> {</b></p><p> cout<&l
52、t;"\t\t\t 沒有找到要字符\n"; </p><p> position[y]=-1;</p><p><b> }</b></p><p><b> n=y; //n</b></p><p><b> }</b></p>
53、<p><b> 圖2-5</b></p><p><b> ?。?)替換模塊</b></p><p> 在字符串內(nèi),把某些小段字符串替換為你想要的字符串。先輸入你要改變的小段字符串,程序先找到這些字符串,再輸入想要替換成的/字符串,程序完成替換功能。其程序如下</p><p> void Str::ins
54、tead_str(Str &s1,Str s2,Str ss1,Str ss2,int n)</p><p><b> {</b></p><p> s1.find_position(s1,ss1,n);</p><p><b> if(n!=0) </b></p><p><b
55、> {</b></p><p> cout<<"\t\t\t 輸入你想替代的字符.\n";</p><p> ss2.input_str();</p><p> cout<<"\t\t\t 替換成功"<<"\n";</p>&l
56、t;p> cout<<"s1.len="<<s1.len<<"\n";</p><p> cout<<"ss1.len="<<ss1.len<<"\n";</p><p> cout<<"ss2.len=&
57、quot;<<ss2.len<<"\n";</p><p> cout<<"n="<<n<<"\n\n";</p><p> if( (s1.len-(ss1.len-ss2.len)*n)>MaxSize)</p><p> cou
58、t<<"太長.\n";</p><p><b> else </b></p><p><b> { </b></p><p><b> int p=0;</b></p><p> position[n]=s1.len+1;</p
59、><p> for(int i=0;i<position[0]-1;i++)</p><p><b> {</b></p><p> s2.ch[p]=s1.ch[i];</p><p><b> p++;</b></p><p><b> }</
60、b></p><p> for(int nn=0;nn<n;nn++)</p><p><b> { </b></p><p> for(int j=0;j<4;j++)</p><p><b> { </b></p><p> s2.c
61、h[p]=ss2.ch[j]; </p><p><b> p++; </b></p><p><b> } </b></p><p> for(int kk=(position[nn]-1+ss1.len);kk<position[nn+1]-1;kk++)</p><p><
62、;b> { </b></p><p> s2.ch[p]=s1.ch[kk];</p><p><b> p++; </b></p><p><b> }</b></p><p><b> }</b></p><p>
63、 s2.ch[p]='#';</p><p><b> s2.len=p;</b></p><p> for(int qq=0; s2.ch[qq]!='#'; qq++)</p><p> s1.ch[qq]=s2.ch[qq];</p><p> s1.ch[qq]='
64、#';</p><p> s1.len=s2.len ;</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> ?。?)退出</b>
65、;</p><p> 當(dāng)所要運(yùn)行操作完成時(shí),可通過主函數(shù)選擇退出菜單,實(shí)現(xiàn)程序的退出。程序運(yùn)行截圖如圖2-6</p><p><b> 圖2-6</b></p><p><b> 5.【總結(jié)】</b></p><p> 通過為期一周的課程設(shè)計(jì),我們對《C語言》這門課程有了更深一步的了解。它是
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 簡單的行編輯器課程設(shè)計(jì)
- c++課程設(shè)計(jì)--簡單的行編輯器
- vb編輯器課程設(shè)計(jì)報(bào)告
- c++課程設(shè)計(jì)--簡單文本編輯器的設(shè)計(jì)
- 文本編輯器課程設(shè)計(jì)報(bào)告
- 虛擬的java編輯器課程設(shè)計(jì)報(bào)告
- 簡易文本編輯器課程設(shè)計(jì)報(bào)告
- vb課程設(shè)計(jì)報(bào)告----文本編輯器
- vb課程設(shè)計(jì)報(bào)告---文本編輯器
- 文本編輯器課程設(shè)計(jì)
- java課程設(shè)計(jì)---文本編輯器
- java課程設(shè)計(jì)---文本編輯器
- java課程設(shè)計(jì)--文本編輯器
- 文本編輯器_java課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
- vb課程設(shè)計(jì)文本編輯器
- java課程設(shè)計(jì)(文本編輯器)
- visual_basic課程設(shè)計(jì)報(bào)告---文本編輯器
- c語言課程設(shè)計(jì)--文本編輯器
- c_文本編輯器課程設(shè)計(jì)
- java課程設(shè)計(jì)報(bào)告-- 文本編輯器的設(shè)計(jì)與實(shí)現(xiàn)
評論
0/150
提交評論