數(shù)據(jù)結構課程設計報告--簡單計算器_第1頁
已閱讀1頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  計算機科學與信息工程學院</p><p><b>  數(shù)據(jù)結構課程設計</b></p><p>  設計題目:簡單計算器</p><p>  2010 年 12 月 25 日</p><p><b>  簡單計算器</b></p><p><b&g

2、t;  一 基本功能描述</b></p><p>  簡單的計算器的功能是對基本的加、減、乘、除、四則運算,可對輸入的操作數(shù),包括整數(shù),小數(shù)等進行運算。</p><p><b>  二 設計思路</b></p><p>  本程序主要是采用棧的理論知識,主要用到兩個結構體棧,一個用來轉化表達式,一個用來計算表達式。區(qū)別就在于一個存儲

3、字符,一個存儲浮點。首先,用一個字符數(shù)組來存儲用戶輸入的中綴表達式。然后用棧來把這個表達式轉化為后綴表達式,轉化時要進行符號優(yōu)先級比較,這里將‘*’‘/’的優(yōu)先級定為2,‘+’‘-’定為1,括號和‘=’定為0。具體思想如下:例如用戶輸入了1+2*3=,將其存放入一個字符數(shù)組中。先在棧的底部存放一個‘=’號符,用作符號優(yōu)先級比較。首先將1存放到另外一個字符數(shù)組s1中,再將‘+’號入棧。入棧的同時與底部的‘=’比較優(yōu)先級,‘+’的優(yōu)先級高于

4、‘=’,所以不出棧,之后將2存放入s2中,然后再將‘*’入棧,入棧的同時與‘+’比較符號優(yōu)先級,‘*’比‘+’高,所以不出棧。再將3存入s2中。之后將棧中不是‘=’的運算符都彈出棧,并依次存入s2中。所以s2中的表達式為123*+。之后進行計算,計算時用到浮點棧。首先將s2中的字符依次入棧,遇到運算符時進行計算。所以將123入棧后,再將‘*’入棧的同時,將前面兩個數(shù)字進行運算,算出結果為6并存入棧中,之后再將‘+’入棧,再與1進行運算,

5、結果即為7</p><p><b>  三 概要設計</b></p><p><b>  1,子函數(shù)功能</b></p><p>  struct Stack{……}</p><p>  用來轉化表達式的機構體棧。</p><p>  Struct FStack{……}<

6、;/p><p>  用來計算表達式的結構體棧</p><p>  void InitStack(Stack &s)</p><p><b>  初始化結構體棧</b></p><p>  void InitFStack(FStack &s)</p><p><b>  初始化

7、結構體棧</b></p><p>  char GetTop(Stack s)</p><p><b>  獲取棧頂數(shù)據(jù)</b></p><p>  void IncrementStackSize(Stack &s)</p><p>  為棧擴充ncrementsize個存儲空間</p>

8、<p>  void IncrementFStackSize(FStack &s)</p><p>  為棧擴充ncrementsize個存儲空間</p><p>  void Push(Stack &s,char e)</p><p><b>  第一個棧入棧操作</b></p><p> 

9、 void PushF(FStack &s,float e)</p><p><b>  第二個棧入棧操作</b></p><p>  bool Empty(Stack s)</p><p>  判斷第一個棧是否為空。</p><p>  bool EmptyF(FStack s)</p><

10、p><b>  判斷第二個棧是否空</b></p><p>  char Pop(Stack &s)</p><p><b>  表達式出棧</b></p><p>  float PopF(FStack &s)</p><p><b>  計算的數(shù)據(jù)出棧</b

11、></p><p>  int Precede(char op)</p><p><b>  確定優(yōu)先級的函數(shù)</b></p><p>  void Change(char *s1,char *s2)</p><p>  改變兩個字符串的儲存位置</p><p>  float Compu

12、te(char *s2)</p><p><b>  實現(xiàn)數(shù)據(jù)的運算</b></p><p><b>  2 函數(shù)的調用</b></p><p>  3 測試數(shù)據(jù)及測試結果</p><p>  (1)測試 1+2+3=6</p><p>  (2) 測試2*4=8</p

13、><p>  (3)測試 3/2=1.5</p><p>  (4)測試(1+2)*3=9</p><p><b>  四 程序代碼</b></p><p>  #include <iostream.h></p><p>  #include <fstream.h></p

14、><p>  #include <string.h></p><p>  #include <ctype.h></p><p>  #include <stdlib.h></p><p>  #include <strstrea.h></p><p>  struct Sta

15、ck{ //轉換表達式</p><p>  char *elem;</p><p><b>  int top;</b></p><p>  int stacksize;</p><p>  int incrementsize;</p><p><b>  };&

16、lt;/b></p><p>  struct FStack{ //計算</p><p>  float *elem;</p><p><b>  int top;</b></p><p>  int stacksize;</p><p>  int incrementsi

17、ze;</p><p><b>  };</b></p><p>  void InitStack(Stack &s)</p><p><b>  {</b></p><p>  s.elem=new char[100];</p><p><b>  s.t

18、op=-1;</b></p><p>  s.stacksize=100;</p><p>  s.incrementsize=10;</p><p><b>  }</b></p><p>  void InitFStack(FStack &s)</p><p><b&

19、gt;  {</b></p><p>  s.elem=new float[100];</p><p><b>  s.top=-1;</b></p><p>  s.stacksize=100;</p><p>  s.incrementsize=10;</p><p><b&

20、gt;  }</b></p><p>  char GetTop(Stack s)</p><p><b>  {</b></p><p>  return s.elem[s.top];</p><p><b>  }</b></p><p>  void Inc

21、rementStackSize(Stack &s)</p><p><b>  {</b></p><p>  char *a=new char[s.stacksize+s.incrementsize];</p><p>  for(int i=0;i<=s.top;i++)</p><p>  a[i]=

22、s.elem[i];</p><p>  delete []s.elem;</p><p><b>  s.elem=a;</b></p><p>  s.stacksize+=s.incrementsize;</p><p><b>  }</b></p><p>  vo

23、id IncrementFStackSize(FStack &s)</p><p><b>  {</b></p><p>  float *a=new float[s.stacksize+s.incrementsize];</p><p>  for(int i=0;i<=s.top;i++)</p><p&

24、gt;  a[i]=s.elem[i];</p><p>  delete []s.elem;</p><p><b>  s.elem=a;</b></p><p>  s.stacksize+=s.incrementsize;</p><p><b>  }</b></p><

25、;p>  void Push(Stack &s,char e)</p><p><b>  {</b></p><p>  if(s.top==(s.stacksize-1))</p><p>  IncrementStackSize(s);</p><p><b>  s.top++;<

26、/b></p><p>  s.elem[s.top]=e;</p><p><b>  }</b></p><p>  void PushF(FStack &s,float e)</p><p><b>  {</b></p><p>  if(s.top=

27、=(s.stacksize-1))</p><p>  IncrementFStackSize(s);</p><p><b>  s.top++;</b></p><p>  s.elem[s.top]=e;</p><p><b>  }</b></p><p>  bo

28、ol Empty(Stack s)</p><p><b>  {</b></p><p>  return s.top==-1;</p><p><b>  }</b></p><p>  bool EmptyF(FStack s)</p><p><b>  {

29、</b></p><p>  return s.top==-1;</p><p><b>  }</b></p><p>  char Pop(Stack &s) //表達式出棧</p><p><b>  {</b></p><p>  

30、return s.elem[s.top--];</p><p><b>  }</b></p><p>  float PopF(FStack &s) //計算的數(shù)據(jù)出棧</p><p><b>  {</b></p><p>  return s.elem[s.top--];<

31、;/p><p><b>  }</b></p><p>  int Precede(char op) //確定優(yōu)先級的函數(shù)</p><p><b>  {</b></p><p>  switch (op)</p><p><b>  {</b>&l

32、t;/p><p><b>  case '+':</b></p><p><b>  case '-':</b></p><p>  return 1; //定義加減運算的優(yōu)先級為1</p><p><b>  case '*':&

33、lt;/b></p><p><b>  case '/':</b></p><p>  return 2; //定義乘除運算的優(yōu)先級為2</p><p><b>  case '(':</b></p><p><b>  case 

34、9;[':</b></p><p><b>  case '{':</b></p><p><b>  case '=':</b></p><p><b>  default:</b></p><p>  return 0;

35、 //定義在棧中的左括號和棧底字符的優(yōu)先級為0</p><p><b>  }</b></p><p><b>  }</b></p><p>  void Change(char *s1,char *s2)</p><p><b>  {</b></p>

36、;<p>  Stack R; //定義用于暫存運算符的棧</p><p>  InitStack(R);</p><p>  Push(R,'='); //給棧底放入‘='字符,它具有最低優(yōu)先級0</p><p><b>  int i,j;</b></p><

37、p>  i = 0; //用于指示掃描s1串中字符的位置,初值為0</p><p>  j = 0; //用于指示s2串中待存字符的位置,初值為0</p><p>  char ch = s1[i];</p><p>  while (ch != '=')</p><p><b>

38、  {</b></p><p>  if (ch == ' ')</p><p><b>  {</b></p><p>  ch = s1[++i]; //對于空格字符不做任何處理</p><p><b>  }</b></p><p>

39、  //-------------------------------------------------------------</p><p>  else if (ch == '(')</p><p>  { //對于左括號,直接進棧</p><p>  Push(R,ch);<

40、;/p><p>  ch = s1[++i];</p><p><b>  }</b></p><p>  else if (ch == ')')</p><p>  { //對于右括號,使括號內的仍停留在棧中的運算符依次出棧并寫入到s2中&

41、lt;/p><p>  while (GetTop(R) != '(')</p><p><b>  {</b></p><p>  s2[j++] = Pop(R);</p><p><b>  }</b></p><p>  Pop(R);

42、 //刪除棧頂?shù)淖罄ㄌ?lt;/p><p>  ch = s1[++i];</p><p><b>  }</b></p><p>  //-------------------------------------------------</p><p>  else if (ch == '

43、[')</p><p>  { //對于左括號,直接進棧</p><p>  Push(R,ch);</p><p>  ch = s1[++i];</p><p><b>  }</b></p><p>  else if

44、 (ch == ']')</p><p>  { //對于右括號,使括號內的仍停留在棧中的運算符依次</p><p>  //出棧并寫入到s2中</p><p>  while (GetTop(R) != '[')</p><p><b&g

45、t;  {</b></p><p>  s2[j++] = Pop(R);</p><p><b>  }</b></p><p>  Pop(R); //刪除棧頂?shù)淖罄ㄌ?lt;/p><p>  ch = s1[++i];</p><p>&

46、lt;b>  }</b></p><p>  //---------------------------------------------</p><p>  else if (ch == '{')</p><p>  { //對于左括號,直接進棧</p>

47、<p>  Push(R,ch);</p><p>  ch = s1[++i];</p><p><b>  }</b></p><p>  else if (ch == '}')</p><p>  { //對于右括號,使括號

48、內的仍停留在棧中的運算符依次</p><p>  //出棧并寫入到s2中</p><p>  while (GetTop(R) != '{')</p><p><b>  {</b></p><p>  s2[j++] = Pop(R);</p><p><b>  }&

49、lt;/b></p><p>  Pop(R); //刪除棧頂?shù)淖罄ㄌ?lt;/p><p>  ch = s1[++i];</p><p><b>  }</b></p><p>  //---------------------------------------------

50、------</p><p>  else if (ch == '+' || ch == '-' || ch == '*' || ch == '/')</p><p>  { //對于四則運算符,使暫存在棧中的不低于c

51、h優(yōu)先級</p><p>  //的運算符依次出棧并寫入到s2中</p><p>  char w = GetTop(R);</p><p>  while (Precede(w) > Precede(ch))</p><p>  { //

52、優(yōu)先級()函數(shù)返回運算符形參的優(yōu)先級</p><p>  s2[j++] = w;</p><p><b>  Pop(R);</b></p><p>  w = GetTop(R);</p><p><b>  }</b></p><p>  Push(R,ch);<

53、/p><p>  ch = s1[++i];</p><p><b>  }</b></p><p><b>  else</b></p><p>  { //此處為數(shù)字或小數(shù)點字符的處理</p&g

54、t;<p>  while (isdigit(ch) || ch == '.')</p><p><b>  {</b></p><p>  s2[j++] = ch;</p><p>  ch = s1[++i];</p><p><b>  }</b></p&

55、gt;<p>  s2[j++] = ' '; //被轉換后的每個數(shù)值后放一個空格</p><p><b>  }</b></p><p><b>  }</b></p><p>  //----------------------

56、-----------------------------------</p><p>  ch = Pop(R);</p><p>  while (ch != '=')</p><p><b>  {</b></p><p>  s2[j++] = ch;</p><p>  

57、ch = Pop(R);</p><p><b>  }</b></p><p>  s2[j++] = '='; //加入字符串結束符</p><p>  s2[j++] = '\0';</p><p><

58、;b>  }</b></p><p>  float Compute(char *s2)</p><p><b>  {</b></p><p>  FStack S; //用S棧存儲操作數(shù)和中間計算結果</p><p> 

59、 InitFStack(S);</p><p>  istrstream ins(s2); //把s2定義為輸入字符串流對象ins</p><p>  char ch; //用于輸入字符</p><p>  float x;

60、 //用于輸入浮點數(shù)</p><p><b>  ins>>ch;</b></p><p>  while (ch != '=')</p><p><b>  {</b></p><p>  switch

61、 (ch)</p><p><b>  {</b></p><p><b>  case '+':</b></p><p>  x = PopF(S) + PopF(S);</p><p><b>  break;</b></p><p>

62、;<b>  case '-':</b></p><p>  x = PopF(S);</p><p>  x = PopF(S) - x;</p><p><b>  break;</b></p><p><b>  case '*':</b>

63、</p><p>  x = PopF(S) * PopF(S);</p><p><b>  break;</b></p><p><b>  case '/':</b></p><p>  x = PopF(S);</p><p>  x = PopF(S

64、) / x;</p><p><b>  break;</b></p><p><b>  default:</b></p><p>  ins.putback(ch);</p><p><b>  ins>>x;</b></p><p>&

65、lt;b>  }</b></p><p>  PushF(S,x);</p><p><b>  ins>>ch;</b></p><p><b>  }</b></p><p>  if (!EmptyF(S))</p><p><b&g

66、t;  {</b></p><p>  x = PopF(S);</p><p>  if (EmptyF(S)) //如果棧中只有一個值那一定是結果</p><p><b>  {</b></p><p><b>  return x;</b>&l

67、t;/p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void main()//主程序</p><p><b>  {</b></p>

68、<p><b>  FStack s;</b></p><p>  char a[10];</p><p>  float b,c;</p><p>  char str1[50],str2[50]; //暫時存儲表達式</p><p>  char j='y';</p>&l

69、t;p>  cout<<" ***************************歡迎使用本計算器***************************"<<endl<<endl;</p><p><b>  haha:</b></p><p>  while(j=='Y'||j==

70、'y')</p><p><b>  {</b></p><p>  int i=0,m=0,n=0,k=0,l=0,q=0,p=0;</p><p>  cout<<" 請輸入一個以'='字符結束的中綴算術表達式:"<<endl&l

71、t;<endl;</p><p>  cin.getline(str1,sizeof(str1));</p><p>  while(str1[i]!='\0')</p><p><b>  i++;</b></p><p>  if(str1[i-1]!='=')</p>

72、;<p><b>  {</b></p><p>  cout<<"表達式錯誤..請重新輸入.."<<endl<<endl;</p><p>  goto haha;</p><p><b>  }</b></p><p>&l

73、t;b>  i=0;</b></p><p>  while(str1[i]!='\0')</p><p><b>  {</b></p><p>  if(str1[i]=='0'&&str1[i-1]=='/')</p><p><

74、;b>  {</b></p><p>  cout<<"表達式錯誤..請重新輸入.."<<endl<<endl;</p><p>  goto haha;</p><p><b>  }</b></p><p><b>  i++;&l

75、t;/b></p><p><b>  }</b></p><p><b>  i=0;</b></p><p>  while(str1[i]!='\0')</p><p><b>  {</b></p><p>  if(str

76、1[i]=='(')</p><p><b>  m++;</b></p><p>  if(str1[i]==')')</p><p><b>  n++;</b></p><p>  if(str1[i]=='[')</p><

77、p><b>  k++;</b></p><p>  if(str1[i]==']')</p><p><b>  l++;</b></p><p>  if(str1[i]=='{')</p><p><b>  q++;</b><

78、/p><p>  if(str1[i]=='}')</p><p><b>  p++;</b></p><p><b>  i++;</b></p><p><b>  }</b></p><p>  if(m!=n || k!=l ||

79、q!=p)</p><p><b>  {</b></p><p>  cout<<"表達式錯誤..請重新輸入.."<<endl<<endl;</p><p>  goto haha;</p><p><b>  }</b></p>

80、;<p>  Change(str1,str2); //處理結果</p><p>  cout<<"\n求值結果為: "<<str1<<Compute(str2)<<endl;</p><p>  cout<<"是否繼續(xù) :(Y/N)"<<endl;</p

81、><p><b>  cin>>j;</b></p><p>  cin.getline(str1,2);</p><p><b>  }</b></p><p>  cout<<endl<<" *********************

82、感謝使用本計算器*********************"<<endl;</p><p><b>  }</b></p><p><b>  五 課程設計總結</b></p><p><b>  1 收獲</b></p><p>  通過這次課程設計,更

83、進一步了解了棧的原理和應用,同時也鍛煉了數(shù)據(jù)結構在實際中的熟練運用。</p><p><b>  2 心得體會</b></p><p>  在這次數(shù)據(jù)結構設計中遇到了很多實際性的問題,在實際設計中才發(fā)現(xiàn),書本上理論性的東西與在實際運用中的還是有一定的出入的,所以有些問題要不斷地更正以前的錯誤思維。通過這次設計,我懂得了學習的重要性,了解到理論知識與實踐相結合的重要意義

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論