數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--簡易文本編輯器_第1頁
已閱讀1頁,還剩23頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、<p>  計(jì)算機(jī)學(xué)院網(wǎng)絡(luò)工程專業(yè)</p><p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p>  題 目: 簡易文本編輯器 </p><p>  班 級: </p><p>  姓 名:

2、 </p><p>  同組人姓名: </p><p>  起 迄 日 期: 2011-12-27~2011-12-30           </p><p>  課程設(shè)計(jì)地點(diǎn):                  </p><

3、;p>  指導(dǎo)教師: </p><p>  完成日期:2011年12月</p><p><b>  目錄</b></p><p>  設(shè)計(jì)的目的和要求……………………………………………………………1</p><p>  課程設(shè)計(jì)的目的………………………………

4、………………………………1</p><p>  基本要求………………………………………………………………………1</p><p>  課程設(shè)計(jì)任務(wù)要求……………………………………………………………1</p><p>  需求分析………………………………………………………………………1</p><p>  具體設(shè)計(jì)………………………………………

5、………………………………1</p><p>  主程序流程圖…………………………………………………………………1</p><p>  詳細(xì)設(shè)計(jì)功能分析……………………………………………………………1</p><p>  函數(shù)分析 源程序代碼………………………………………………………6</p><p>  調(diào)試分析和測試結(jié)果………………………

6、………………………………19</p><p>  代碼測試截圖結(jié)果分析……………………………………………………19</p><p>  問題解決與分析……………………………………………………………23</p><p>  總結(jié)心得與體會……………………………………………………………24</p><p>  附錄一 參考文獻(xiàn)………………………

7、…………………………………25</p><p>  一.課程設(shè)計(jì)目的和要求</p><p><b>  設(shè)計(jì)目的</b></p><p>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)是一門實(shí)踐性非常強(qiáng)的課程,不但結(jié)合了C語言的設(shè)計(jì)基本知識,更加注重技能的培養(yǎng),是學(xué)生能夠允許漸進(jìn)的把握C語言C++的程序設(shè)計(jì)的技能。通過此課程設(shè)計(jì)可以提高學(xué)生的思維能力,促進(jìn)學(xué)生的綜合應(yīng)用

8、能力和專業(yè)素質(zhì)的提高,同時提以下幾個方面的能力。</p><p>  了解并掌握數(shù)據(jù)結(jié)構(gòu)與算法的設(shè)計(jì)方法,具備初步的獨(dú)立分析和設(shè)計(jì)能力;</p><p>  初步掌握軟件開發(fā)過程的問題分析、系統(tǒng)設(shè)計(jì)、程序編碼、測試等基本方法和技能;</p><p>  提高綜合運(yùn)用所學(xué)的理論知識和方法獨(dú)立分析和解決問題的能力;</p><p>  訓(xùn)練用系統(tǒng)

9、的觀點(diǎn)和軟件開發(fā)一般規(guī)范進(jìn)行軟件開發(fā),培養(yǎng)軟件工作者所應(yīng)具備的科學(xué)的工作方法和作風(fēng)。</p><p><b>  設(shè)計(jì)要求</b></p><p><b>  在C環(huán)境下可以運(yùn)行</b></p><p>  完成老師任務(wù)書上面的要求</p><p>  二.課程設(shè)計(jì)任務(wù)要求</p>&

10、lt;p><b>  需求分析</b></p><p><b>  具有圖形菜單界面;</b></p><p>  查找,替換(等長,不等長),插入(插串,文本塊的插入)、塊移動(行塊,列塊移動),刪除</p><p><b>  可正確存盤、取盤;</b></p><p&g

11、t;<b>  正確顯示總行數(shù)。</b></p><p><b>  三.具體設(shè)計(jì)</b></p><p>  主程序流程圖 如(圖1)所示</p><p>  程序中用鏈表來保存文本,每一行為一個單向鏈表,每一行的表頭保存在一個行鏈表中,形成了一個2維鏈表,結(jié)構(gòu)如下(圖2)所示:</p><p>

12、<b>  詳細(xì)設(shè)計(jì)功能實(shí)現(xiàn)</b></p><p><b>  打開文件</b></p><p>  提示用戶輸入文件路徑</p><p>  判斷文件路徑是否有效,若無效,則提示錯誤信息并返回,否則繼續(xù)執(zhí)行。</p><p>  若文件成功打開并且文件指針沒有到文件尾,則從文件中一次讀取一個字符

13、,并將該字符添加到一列單鏈表節(jié)點(diǎn)中,直至遇到換行符(ASCII碼10)。當(dāng)列單鏈表形成后,它的首地址將被保存至行單鏈表的相應(yīng)節(jié)點(diǎn)的數(shù)據(jù)域中,如此動作,直至文件指針指向文件尾部而結(jié)束。</p><p><b>  新建文件</b></p><p>  若行鏈表中有數(shù)據(jù)存在,則提示用戶保存文件。</p><p>  提示用戶輸入新建文件的保存路徑。

14、</p><p>  測試新文件路徑是否有效。</p><p><b>  保存文件</b></p><p><b>  打開文件。</b></p><p>  遍歷行單鏈表,遍歷行單鏈表節(jié)點(diǎn)指向的列單鏈表,并將數(shù)據(jù)輸出到文件,每個列單鏈表遍歷完后,輸出換行符到文件。</p><

15、p><b>  關(guān)閉文件</b></p><p><b> ?。▓D1)</b></p><p><b>  插入字符串</b></p><p>  提示用戶輸入要插入字符串的位置(行號row,列號col)以及要插入的字符串。</p><p>  先在行單鏈表中找到該行(第

16、row行),若超出現(xiàn)有行數(shù),則添加空行補(bǔ)齊;</p><p>  將字符串插入該行(第row行)節(jié)點(diǎn)指向的列鏈表中的col-1位置,若超出現(xiàn)有節(jié)點(diǎn)數(shù),則添加保存字符為空格的節(jié)點(diǎn)補(bǔ)齊。</p><p><b>  刪除字符串</b></p><p>  提示用戶輸入要刪除字符串的開始位置(行號row,列號col)以及要插入的字符串的長度len。&

17、lt;/p><p>  在鏈表中定位到該行節(jié)點(diǎn),若不存在,則提示無法刪除并返回;否則繼續(xù)執(zhí)行。</p><p>  在該行中定位到該col字符節(jié)點(diǎn)node,若不存在,則提示無法刪除并返回;否則繼續(xù)執(zhí)行。</p><p>  刪除從node字符節(jié)點(diǎn)開始的len個節(jié)點(diǎn)。若不滿len個,則全部刪除。</p><p><b>  查找替換<

18、;/b></p><p>  提示用戶輸入要查找的字符串。</p><p>  遍歷鏈表,找到每一個出現(xiàn)此字符串的位置并輸出。</p><p>  詢問用戶是否要進(jìn)行替換。若選是,則提示用戶輸入要替換后的字符串,然后先在鏈表中刪除原字符串,再在該位置插入要替換為的字符串。</p><p><b>  行移動</b>

19、</p><p>  提示用戶輸入要移動的行row和移動后的位置pos。</p><p>  將行鏈表中的row-1節(jié)點(diǎn)移動到pos-1位置。</p><p><b>  列移動</b></p><p>  提示用戶輸入要移動的列col和移動后的位置pos。</p><p>  遍歷每一行(列鏈表

20、),將每一行的col-1節(jié)點(diǎn)移動到pos位置處;若col-1節(jié)點(diǎn)不存在則不處理。</p><p><b>  顯示文本</b></p><p> ?。?)遍歷行、列鏈表,并將數(shù)據(jù)輸出到控制臺;</p><p><b>  (圖2)</b></p><p>  函數(shù)分析 源程序代碼</p>

21、;<p>  #include <iostream></p><p>  #include <fstream></p><p>  #include <string></p><p>  using namespace std;</p><p>  //#include "Struc

22、t.h"</p><p>  //1、 具有圖形菜單界面;</p><p>  //2、 查找,替換(等長,不等長),插入(插串,文本塊的插入)、塊移動(行塊,列塊移動),刪除</p><p>  //3、 可正確存盤、取盤;</p><p>  //4、正確顯示總行數(shù)。</p><p><b> 

23、 //字符節(jié)點(diǎn)</b></p><p>  struct Node</p><p><b>  {</b></p><p><b>  char ch;</b></p><p>  Node* next;</p><p><b>  };</b&g

24、t;</p><p><b>  //行節(jié)點(diǎn)</b></p><p>  struct Row</p><p><b>  {</b></p><p>  Node* line;</p><p>  Row* next;</p><p><b&g

25、t;  };</b></p><p>  //創(chuàng)建一個Node對象</p><p>  Node* createNode(char ch)</p><p><b>  {</b></p><p>  Node* p = new Node;</p><p><b>  p-&g

26、t;ch=ch;</b></p><p>  p->next=NULL;</p><p><b>  return p;</b></p><p><b>  }</b></p><p>  //創(chuàng)建一個Row對象</p><p>  Row* createR

27、ow(Node* line)</p><p><b>  {</b></p><p>  Row* p=new Row;</p><p>  p->line=line;</p><p>  p->next=NULL;</p><p><b>  return p;</b

28、></p><p><b>  }</b></p><p>  //定位到index處</p><p>  Node* locate(Node* line,int index)</p><p><b>  {</b></p><p>  Node* p=line;<

29、;/p><p><b>  int i=-1;</b></p><p>  while(p!=NULL&&i<index)</p><p><b>  {</b></p><p>  p=p->next;</p><p><b>  i++;

30、</b></p><p><b>  }</b></p><p><b>  return p;</b></p><p><b>  }</b></p><p>  Row* locate(Row* list,int index)</p><p&

31、gt;<b>  {</b></p><p>  Row* p=list;</p><p><b>  int i=-1;</b></p><p>  while(p!=NULL&&i<index)</p><p><b>  {</b></p>

32、;<p>  p=p->next;</p><p><b>  i++;</b></p><p><b>  }</b></p><p><b>  return p;</b></p><p><b>  }</b></p>

33、<p><b>  //插入節(jié)點(diǎn)</b></p><p>  bool insert(Node* list,int index,char c)</p><p><b>  {</b></p><p>  Node* p= locate(list,index-1);</p><p>&l

34、t;b>  if(p)</b></p><p><b>  {</b></p><p>  Node* node=createNode(c);</p><p>  node->next=p->next;</p><p>  p->next=node;</p><p&

35、gt;  return true;</p><p><b>  }</b></p><p>  return false;</p><p><b>  }</b></p><p>  bool insert(Row* list,int index,Node* line)</p><

36、;p><b>  {</b></p><p>  Row* p= locate(list,index-1);</p><p><b>  if(p)</b></p><p><b>  {</b></p><p>  Row* row=createRow(line);&l

37、t;/p><p>  row->next=p->next;</p><p>  p->next=row;</p><p>  return true;</p><p><b>  }</b></p><p>  return false;</p><p>&l

38、t;b>  }</b></p><p><b>  //刪除節(jié)點(diǎn)</b></p><p>  bool remove(Node* list,int index)</p><p><b>  {</b></p><p>  Node* p=locate(list,index-1);&

39、lt;/p><p>  Node* q=NULL;</p><p>  if(p&&p->next)</p><p><b>  {</b></p><p>  q = p->next;</p><p>  p->next=q->next;</p>

40、<p><b>  delete q;</b></p><p>  return true;</p><p><b>  }</b></p><p>  return false;</p><p><b>  }</b></p><p>&l

41、t;b>  //清空鏈表</b></p><p>  void clear(Node* line)</p><p><b>  {</b></p><p>  Node* p=line->next;</p><p><b>  Node* q;</b></p>

42、<p><b>  while(p)</b></p><p><b>  {</b></p><p>  q=p->next;</p><p><b>  delete p;</b></p><p><b>  p=q;</b></p

43、><p><b>  }</b></p><p><b>  }</b></p><p>  bool remove(Row* list,int index)</p><p><b>  {</b></p><p>  Row* p=locate(list,

44、index-1);</p><p>  Row* q=NULL;</p><p>  if(p&&p->next)</p><p><b>  {</b></p><p>  q = p->next;</p><p>  p->next=q->next;&l

45、t;/p><p>  clear(q->line); //清空字符鏈表</p><p>  delete q->line; //刪除字符鏈表表頭</p><p><b>  delete q;</b></p><p>  return true;</p><p><b>  }&

46、lt;/b></p><p>  return false;</p><p><b>  }</b></p><p>  void clear(Row* text)</p><p><b>  {</b></p><p>  Row* p=text->next;&

47、lt;/p><p><b>  Row* q;</b></p><p><b>  while(p)</b></p><p><b>  {</b></p><p>  q=p->next;</p><p>  clear(p->line);&l

48、t;/p><p>  delete p->line; //刪除字符鏈表表頭</p><p><b>  delete p;</b></p><p><b>  p=q;</b></p><p><b>  }</b></p><p><b>

49、  }</b></p><p>  void Line(int i)</p><p><b>  {</b></p><p><b>  if(i==1)</b></p><p><b>  {</b></p><p>  cout<&

50、lt;"-----------------------------------------------------------------------"<<endl;</p><p><b>  }</b></p><p>  else if(i==2)</p><p><b>  {</b>

51、;</p><p>  cout<<"======================================================================="<<endl;</p><p><b>  }</b></p><p><b>  }</b>&l

52、t;/p><p>  int YesOrNo()</p><p><b>  {</b></p><p><b>  char c;</b></p><p><b>  cin>>c;</b></p><p>  if(c=='Y'

53、;||c=='y')</p><p><b>  {</b></p><p><b>  return 1;</b></p><p><b>  }</b></p><p>  else if(c=='N'||c=='n')<

54、;/p><p><b>  {</b></p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  return -1;</p><p><b>  }</b></p>

55、<p><b>  //主菜單</b></p><p>  void Menu()</p><p><b>  {</b></p><p>  cout<<"*****************************************************************

56、*****"<<endl;</p><p>  cout<<"* 簡易文本編輯器 *"<<endl;</p><p>  cout<<"*******************************************

57、***************************"<<endl;</p><p>  cout<<"\t1.打開文件"<<endl;</p><p>  cout<<"\t2.新建文件"<<endl;</p><p>  cout<<&qu

58、ot;\t3.保存文件"<<endl;</p><p>  cout<<"\t4.插入字符串"<<endl;</p><p>  cout<<"\t5.刪除字符串"<<endl;</p><p>  cout<<"\t6.查找替換&qu

59、ot;<<endl;</p><p>  cout<<"\t7.行移動"<<endl;</p><p>  cout<<"\t8.列移動"<<endl;</p><p>  cout<<"\t9.顯示文本"<<endl;&l

60、t;/p><p>  cout<<"\t0.退出"<<endl;</p><p><b>  Line(1);</b></p><p><b>  }</b></p><p><b>  //輸出當(dāng)前文本</b></p>&

61、lt;p>  void PrintText(Row* text)</p><p><b>  {</b></p><p>  cout<<endl;</p><p><b>  Line(2);</b></p><p>  cout<<"當(dāng)前文本為:"

62、;<<endl;</p><p><b>  Line(1);</b></p><p>  Row* p=text->next;</p><p><b>  Node* q;</b></p><p><b>  int i=0;</b></p>

63、<p>  while(p!=NULL)</p><p><b>  {</b></p><p><b>  i++;</b></p><p>  cout<<"行"<<i<<" ";</p><p>  q =

64、 p->line->next;</p><p>  while(q!=NULL)</p><p><b>  {</b></p><p>  cout<<q->ch;</p><p>  q=q->next;</p><p><b>  }</b

65、></p><p>  cout<<endl;</p><p>  p=p->next;</p><p><b>  }</b></p><p><b>  Line(1);</b></p><p>  cout<<"總共 &

66、quot;<<i<<" 行"<<endl;</p><p><b>  Line(2);</b></p><p><b>  }</b></p><p><b>  //打開文件</b></p><p>  bool Op

67、enFile(char * fileName,Row* text)</p><p><b>  {</b></p><p>  ifstream file(fileName,ios::in);</p><p><b>  if(!file)</b></p><p><b>  {</

68、b></p><p>  cout<<"文件讀取失??!"<<endl;</p><p>  return false;</p><p><b>  }</b></p><p><b>  char c;</b></p><p>

69、;<b>  Row* rp;</b></p><p><b>  rp=text;</b></p><p>  while(!file.eof())</p><p><b>  {</b></p><p>  Node* line=new Node;</p>&

70、lt;p>  line->next=NULL;</p><p>  Node* p=line;</p><p>  file.get(c);</p><p>  while(c!=10&&!file.eof())</p><p><b>  {</b></p><p>

71、  Node* q=createNode(c);</p><p>  q->next=NULL;</p><p>  p->next=q;</p><p>  p=p->next;</p><p>  file.get(c);</p><p><b>  }</b></p&

72、gt;<p>  /*if(c==10)</p><p><b>  {</b></p><p>  row.add('\n');</p><p><b>  }*/</b></p><p>  if(!file.eof())</p><p>&

73、lt;b>  {</b></p><p>  Row* rq = createRow(line);</p><p>  rp->next=rq;</p><p>  rp=rp->next;</p><p><b>  }</b></p><p><b> 

74、 }</b></p><p>  file.close();</p><p>  cout<<"文件讀取完成!"<<endl;</p><p>  return true;</p><p><b>  }</b></p><p><b&

75、gt;  //創(chuàng)建文件</b></p><p>  bool CreateFile(const char * fileName,Row* text)</p><p><b>  {</b></p><p>  ofstream file(fileName);</p><p><b>  if(!fi

76、le)</b></p><p><b>  {</b></p><p>  cout<<"文件創(chuàng)建失??!"<<endl;</p><p>  return false;</p><p><b>  }</b></p><p&

77、gt;  file.close();</p><p>  cout<<"文件創(chuàng)建成功!"<<endl;</p><p>  return true;</p><p><b>  }</b></p><p><b>  //保存</b></p>

78、<p>  bool SaveFile(const char * fileName,Row* text)</p><p><b>  {</b></p><p>  ofstream file(fileName);</p><p><b>  if(!file)</b></p><p>

79、<b>  {</b></p><p>  cout<<"文件保存失??!"<<endl;</p><p>  return false;</p><p><b>  }</b></p><p>  Row* p=text->next;</p&g

80、t;<p>  Node* q=NULL;</p><p>  while(p!=NULL)</p><p><b>  {</b></p><p>  q = p->line->next;</p><p>  while(q!=NULL)</p><p><b&g

81、t;  {</b></p><p>  //if(q->data=='\n')</p><p>  file<<q->ch;</p><p>  q=q->next;</p><p><b>  }</b></p><p>  file&l

82、t;<endl;</p><p>  p=p->next;</p><p><b>  }</b></p><p>  file.close();</p><p>  cout<<"文件保存成功!"<<endl;</p><p>  retu

83、rn true;</p><p><b>  }</b></p><p><b>  //插入字符串</b></p><p>  void InsertStr(Row* text,int row,int col)</p><p><b>  {</b></p>&

84、lt;p>  int i=-1,j=-1;</p><p>  Row *rp,*rq;</p><p>  Node *np,*nq;</p><p><b>  rp=text;</b></p><p>  while(rp->next&&i<row)</p><

85、p><b>  {</b></p><p>  rp=rp->next;</p><p><b>  i++;</b></p><p><b>  }</b></p><p>  while(i<row)</p><p><b&g

86、t;  {</b></p><p>  nq=createNode(' ');//定義一個新行鏈表</p><p>  rq=createRow(nq);</p><p>  rp->next=rq;</p><p>  rp=rp->next;</p><p><b>

87、;  i++;</b></p><p><b>  }</b></p><p>  np=rp->line;</p><p>  while(np->next&&j<col-1)</p><p><b>  {</b></p><p&

88、gt;  np=np->next;</p><p><b>  j++;</b></p><p><b>  }</b></p><p>  while(j<col-1)</p><p><b>  {</b></p><p>  nq=cr

89、eateNode(' ');</p><p>  np->next=nq;</p><p>  np=np->next;</p><p><b>  j++;</b></p><p><b>  }</b></p><p>  cin.get();

90、</p><p><b>  string s;</b></p><p>  getline(cin,s);</p><p>  for(int k=0;k<s.length();k++)</p><p><b>  {</b></p><p>  nq=createN

91、ode(s[k]);</p><p>  nq->next=np->next;</p><p>  np->next=nq;</p><p>  np=np->next;</p><p><b>  }</b></p><p><b>  }</b>&

92、lt;/p><p><b>  //行移動</b></p><p>  bool MoveRow(Row* text,int row,int poz)</p><p><b>  {</b></p><p>  if(row==poz)</p><p><b>  {&

93、lt;/b></p><p>  return true;</p><p><b>  }</b></p><p>  Row* p=locate(text,row-1);</p><p>  Row* t=locate(text,poz-1);</p><p><b>  Row

94、* q;</b></p><p>  if(p&&p->next&&t)</p><p><b>  {</b></p><p>  q=p->next;</p><p>  p->next=q->next;</p><p>  

95、q->next=t->next;</p><p>  t->next=q;</p><p>  return true;</p><p><b>  }</b></p><p>  return false;</p><p><b>  }</b></

96、p><p><b>  //列移動</b></p><p>  void MoveCol(Row* text,int col,int poz)</p><p><b>  {</b></p><p>  if(col==poz)</p><p><b>  return

97、;</b></p><p>  Row* rp=text->next;</p><p><b>  while(rp)</b></p><p><b>  {</b></p><p>  Node* np=locate(rp->line,col-1);</p>

98、<p>  Node* nt=locate(rp->line,poz-1);</p><p><b>  Node* nq;</b></p><p>  if(np&&np->next&&nt)</p><p><b>  {</b></p><p&

99、gt;  nq=np->next;</p><p>  np->next=nq->next;</p><p>  nq->next=nt->next;</p><p>  nt->next=nq;</p><p><b>  }</b></p><p> 

100、 rp=rp->next;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  //查找替換</b></p><p>  void FindStr(Row* text)</p><p><

101、;b>  {</b></p><p>  string str,rep;</p><p>  int pos,k=0,row=1,col=0;</p><p>  cout<<"請輸入你要查找的字符串:"<<endl;</p><p><b>  cin>>s

102、tr;</b></p><p>  Row* p=text->next;</p><p><b>  while(p)</b></p><p><b>  {</b></p><p>  string line;</p><p>  Node* nq=p-&

103、gt;line->next;</p><p><b>  while(nq)</b></p><p><b>  {</b></p><p>  line.append(1,nq->ch);</p><p>  nq=nq->next;</p><p>&l

104、t;b>  }</b></p><p>  pos=line.find(str.c_str(),0);</p><p>  while(pos!=string::npos)</p><p><b>  {</b></p><p><b>  col=pos;</b></p&g

105、t;<p><b>  k++;</b></p><p>  cout<<str<<" 第"<<k<<"次出現(xiàn)的位置是:第"<<row<<"行,第"<<col+1<<"列"<<endl;<

106、;/p><p>  cout<<"是否替換?(Y/N) ";</p><p>  int yon=YesOrNo();</p><p>  while(yon==-1)</p><p><b>  {</b></p><p>  cout<<"是否

107、替換?(Y/N) ";</p><p>  yon=YesOrNo();</p><p><b>  }</b></p><p>  if(yon==1)</p><p><b>  {</b></p><p>  cout<<"將 "

108、;<<str<<" 替換為:";</p><p><b>  cin>>rep;</b></p><p><b>  int j;</b></p><p>  for(j=0;j<str.length();j++)</p><p><

109、;b>  {</b></p><p>  remove(p->line,col);</p><p><b>  }</b></p><p>  for(j=0;j<rep.length();j++)</p><p><b>  {</b></p><

110、p>  insert(p->line,col+j,rep[j]);</p><p><b>  }</b></p><p>  cout<<"替換成功!"<<endl;</p><p><b>  }</b></p><p>  pos=lin

111、e.find(str.c_str(),col+str.length());</p><p><b>  }</b></p><p><b>  row++;</b></p><p>  p=p->next;</p><p><b>  }</b></p>&

112、lt;p><b>  if(k==0)</b></p><p><b>  {</b></p><p>  cout<<"當(dāng)前文本中找不到該字符串!"<<endl;</p><p><b>  }</b></p><p><

113、;b>  }</b></p><p>  void DelStr(Row* text,int row,int col,int len)</p><p><b>  {</b></p><p>  Row* rp = locate(text,row);</p><p>  if(rp==NULL)<

114、/p><p><b>  {</b></p><p>  cout<<"無法刪除,因?yàn)樵撐恢脹]有字符串!"<<endl;</p><p><b>  return;</b></p><p><b>  }</b></p>&

115、lt;p>  Node* np = locate(rp->line,col-1);</p><p>  if(np==NULL)</p><p><b>  {</b></p><p>  cout<<"無法刪除,因?yàn)樵撐恢脹]有字符串!"<<endl;</p><p&g

116、t;<b>  return;</b></p><p><b>  }</b></p><p>  Node* nq=np->next;</p><p><b>  string s;</b></p><p><b>  int k=0;</b>&l

117、t;/p><p>  while(nq&&k<len)</p><p><b>  {</b></p><p>  s.append(1,nq->ch);</p><p>  np->next=nq->next;</p><p>  delete nq;<

118、/p><p>  nq=np->next;</p><p><b>  k++;</b></p><p><b>  }</b></p><p>  cout<<"成功刪除字符串 "<<s<<endl;</p><p>

119、;<b>  }</b></p><p>  int main()</p><p><b>  {</b></p><p>  bool flag=false;</p><p>  int sel,row,col,poz;</p><p>  Row* text=new Ro

120、w;</p><p>  text->next=NULL;</p><p>  string fileName;</p><p><b>  Menu();</b></p><p>  cout<<"請選擇操作:";</p><p><b>  ci

121、n>>sel;</b></p><p>  while(sel!=0)</p><p><b>  {</b></p><p>  switch(sel)</p><p><b>  {</b></p><p>  case 1: //打開文件

122、</p><p>  cout<<"請輸入要打開的文件路徑(例如 E:\\1.txt):";</p><p>  cin>>fileName;</p><p>  flag = OpenFile((char *)fileName.c_str(),text);</p><p><b>

123、  if(flag)</b></p><p><b>  {</b></p><p>  PrintText(text);</p><p><b>  }</b></p><p><b>  break;</b></p><p>  case

124、 2: //新建文件</p><p><b>  if(flag)</b></p><p><b>  {</b></p><p>  cout<<"要保存前一個文件嗎?(Y/N) ";</p><p>  int yon=YesOrNo();</p&

125、gt;<p>  while(yon==-1)</p><p><b>  {</b></p><p>  cout<<"要保存前一個文件嗎?(Y/N) ";</p><p>  yon=YesOrNo();</p><p><b>  }</b>&l

126、t;/p><p>  if(yon==1)</p><p><b>  {</b></p><p>  SaveFile((char *)fileName.c_str(),text);</p><p><b>  }</b></p><p>  flag = false;

127、</p><p><b>  }</b></p><p>  clear(text);</p><p>  cout<<"請輸入要新建的文件路徑(例如 E:\\1.txt):";</p><p>  cin>>fileName;</p><p> 

128、 flag = CreateFile((char *)fileName.c_str(),text);</p><p><b>  if(flag)</b></p><p><b>  {</b></p><p>  PrintText(text);</p><p><b>  }</

129、b></p><p><b>  break;</b></p><p>  case 3: //保存文件</p><p><b>  if(flag)</b></p><p><b>  {</b></p><p>  SaveFile((cha

130、r *)fileName.c_str(),text);</p><p>  flag = false;</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  co

131、ut<<"請輸入文件路徑:";</p><p>  cin>>fileName;</p><p>  flag = SaveFile((char *)fileName.c_str(),text);</p><p><b>  }</b></p><p><b>  b

132、reak;</b></p><p>  case 4: //插入字符串</p><p>  cout<<"請選擇要插入的位置(第x行第y個字符之后):"<<endl;</p><p>  cout<<"行: ";</p><p><b>  c

133、in>>row;</b></p><p>  cout<<"列:";</p><p><b>  cin>>col;</b></p><p>  cout<<"請輸入要插入的字符串:";</p><p><b>

134、  row--;</b></p><p><b>  col--;</b></p><p>  InsertStr(text,row,col);</p><p>  cout<<"插入成功!"<<endl;</p><p>  PrintText(text);<

135、;/p><p><b>  break;</b></p><p>  case 5: //刪除字符串</p><p><b>  int len;</b></p><p>  cout<<"請選擇要刪除的字符串的開始位置(第x行第y個字符):"<<endl;

136、</p><p>  cout<<"行: ";</p><p><b>  cin>>row;</b></p><p>  cout<<"列:";</p><p><b>  cin>>col;</b></

137、p><p>  cout<<"請輸入要刪除的字符串的長度:";</p><p><b>  cin>>len;</b></p><p><b>  row--;</b></p><p><b>  col--;</b></p>

138、<p>  DelStr(text,row,col,len);</p><p>  PrintText(text);</p><p><b>  break;</b></p><p>  case 6: //查找替換字符串</p><p>  FindStr(text);</p><p

139、>  PrintText(text);</p><p><b>  break;</b></p><p>  case 7: //行移動</p><p>  cout<<"請選擇你要移動的行:";</p><p><b>  cin>>row;</b&g

140、t;</p><p>  cout<<"你想要將第"<<row<<"行移動到第幾行之前? >:";</p><p><b>  cin>>poz;</b></p><p><b>  row--;</b></p>&

141、lt;p><b>  poz--;</b></p><p>  if(MoveRow(text,row,poz))</p><p><b>  {</b></p><p>  cout<<"移動完成!"<<endl;</p><p><b>

142、;  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  cout<<"無法移動!"<<endl;</p><p><b>  }</b></p>

143、;<p>  PrintText(text);</p><p><b>  break;</b></p><p>  case 8: //列移動</p><p>  cout<<"請選擇你要移動的列:";</p><p><b>  cin>>col;&

144、lt;/b></p><p>  cout<<"你想要將第"<<col<<"列移動到第幾列之前? >:";</p><p><b>  cin>>poz;</b></p><p><b>  col--;</b></p

145、><p><b>  poz--;</b></p><p>  MoveCol(text,col,poz);</p><p>  cout<<"移動完成!"<<endl;</p><p>  PrintText(text);</p><p><b>

146、;  break;</b></p><p>  case 9: //顯示文本</p><p>  PrintText(text);</p><p><b>  break;</b></p><p><b>  default:</b></p><p><b&

147、gt;  break;</b></p><p><b>  }</b></p><p>  cout<<"請選擇操作:";</p><p><b>  cin>>sel;</b></p><p><b>  }</b>&l

148、t;/p><p><b>  if(flag)</b></p><p><b>  {</b></p><p>  cout<<"要保存前一個文件嗎?(Y/N) ";</p><p>  int yon=YesOrNo();</p><p>  

149、while(yon==-1)</p><p><b>  {</b></p><p>  cout<<"要保存前一個文件嗎?(Y/N) ";</p><p>  yon=YesOrNo();</p><p><b>  }</b></p><p&

150、gt;  if(yon==1)</p><p><b>  {</b></p><p>  SaveFile((char *)fileName.c_str(),text);</p><p><b>  }</b></p><p>  flag = false;</p><

151、p><b>  }</b></p><p>  clear(text);</p><p>  delete text;</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  四.調(diào)試分析

152、和測試結(jié)果</p><p>  代碼測試截圖結(jié)果分析</p><p><b>  主菜單圖形界面</b></p><p>  注:通過該見面進(jìn)入簡易文本編輯器的操作</p><p><b>  新建文本運(yùn)行界面</b></p><p>  注:在選擇了正確的存儲路徑后才可新建

153、文件,新建文件后就自動保存一空的文檔</p><p><b>  插入字符串運(yùn)行界面</b></p><p>  注:在新建的文件中插入字符串</p><p><b>  刪除字符串運(yùn)行界面</b></p><p><b>  插入替換運(yùn)行界面</b></p>&

154、lt;p><b>  移動行列運(yùn)行界面</b></p><p>  注:在編輯文本時可能出現(xiàn)錯誤,用有些移動刪除來及解決,此界面對比出文本前后</p><p><b>  顯示文本運(yùn)行界面</b></p><p>  注:每進(jìn)行一次操作文本就更新,操作9 是又新建的空文本經(jīng)過一些列的操作后最終顯示的文件</p&

155、gt;<p><b>  3問題解決與分析</b></p><p><b>  如下界面</b></p><p>  當(dāng)你保存的文件路徑不對時,程序運(yùn)行會出現(xiàn)異常,輸入了正確的路徑如代碼中的示范程序才正常運(yùn)行</p><p>  沒有按照程序代碼的指令來,會導(dǎo)致運(yùn)行錯誤</p><p>

156、;<b>  五.總結(jié)心得與體會</b></p><p>  這次課程的設(shè)計(jì)使我認(rèn)識到知識的學(xué)習(xí)不能只局限于課本,更使我明白時間的編碼能力和實(shí)踐能力非常重要,而在以后我們所編寫的程序是面向?qū)ο蟮?,編寫的程序是給用戶用的,不能單單的以控制臺輸出,這是我現(xiàn)在所未想到的最大缺陷。通過此次的課程設(shè)計(jì),我又更好的掌握了Visual C++的環(huán)境和語法,熟悉了其結(jié)構(gòu),提高的程序的編寫能力和程序分析能力,

157、并學(xué)會了用Visual C++來解決實(shí)際中的一些簡單的問題,了解了程序的設(shè)計(jì)原則及方法,也學(xué)會了一些算法的思想,并切實(shí)感受到好的算法對編程所帶來的巨大好處,這同時也提高了我對實(shí)際問題的分析能力,為以后的學(xué)習(xí)做了一個好的開端。同時明白要學(xué)的東西太多了,非常感謝這次給予我?guī)妥⒌耐瑢W(xué),要虛心請教,這樣才能更快的提高自己去的更大的進(jìn)步。</p><p>  附錄一 參考文獻(xiàn):</p><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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論