青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

誓言不會融化的那個夏天Using Namespace乖狗狗

GOTO 乖狗狗的綜合博客『有78篇新文章』

【乖狗狗※熱狗】原創音樂,聆聽字里行間的溫柔

【狗眼看股】 獨特的眼光,深刻的分析,精準的預測
記不住網址?沒關系,在絕大多數搜索引擎中,使用“乖狗狗”作為關鍵詞進行搜索,本站將出現在搜索排行中的第位!

posts - 3,comments - 21,trackbacks - 0
這是我2005年初學C++時的一個小作品,雖然很不好
但為保持原汁原味,至今未做改進,供大家參考
主要的兩個小技巧:
1是對e的處理
2是對負號的處理
開發環境:VC++ 7.0


Calculator.h : 頭文件


 1// Calculator.h : 頭文件 
 2// 
 3#ifndef CALCULATOR_H_2005_04_27__ 
 4#define CALCULATOR_H_2005_04_27__ 
 5
 6
 7#include <stack> 
 8
 9using namespace std;
10
11typedef stack<double> STACK_DOUBLE; 
12typedef stack<char> STACK_CHAR; 
13
14
15class CCalculator 
16
17 public : 
18  double CountResult(CString csExp); 
19  int CheckString(CString csExp); 
20  int ReturnError(CString csExp); 
21  CCalculator(void); 
22
23 private
24  STACK_DOUBLE m_doubleStack;  //操作數棧 
25  STACK_CHAR m_charStack;  //操作符號棧 
26  static char m_priTable[8][8]; //運算符優先級列表 
27
28  char QueryPri(char chOperator1,char chOperator2);  
29   //查找運算符優先級 
30
31  //int JudgeOperator(char ch); 
32  // //判斷是否為操作符號 
33
34  int JudgeOperator(CString csExp, int iLocation); 
35   //判斷是否為操作符號 
36
37  double Count(double dbNum1,double dbNum2, char chOper); 
38         //四則運算函數,返回計算結果 
39
40  double GetCurrentDouble(CString csExpression,int& iCurrentLocation); 
41   //從表達式的當前位置查找操作數并返回,當前位置向前移動 
42
43   
44}

45
46
47#endif 
48
49


Calculator.cpp


  1//Calculator.cpp 
  2
  3
  4#include "stdafx.h" 
  5#include "Calculator.h" 
  6#include <stack> 
  7#include <math.h> 
  8
  9using namespace std;
 10
 11
 12//檢查表達式是否合法 
 13int CCalculator::CheckString(CString csExp ) 
 14
 15  
 16 return 1
 17  
 18}

 19
 20//計算合法表達式的值 
 21double CCalculator::CountResult(CString csExp) 
 22{   
 23 int i = 0
 24 int j = 0
 25 int iLength = 0
 26 int& alia_i = i; 
 27 char chMyOperator = '\0'
 28 char chCompareResult = '\0'
 29 char chCurrent = '\0'
 30 char chTop = '\0'
 31 double dbNumber1 = 0.0
 32 double dbNumber2 = 0.0
 33 double dbResult = 0.0
 34 double dbCurrentNumber = 0.0
 35  
 36 csExp += "#"
 37 iLength = csExp.GetLength();  //獲取表達式的長度 
 38 m_charStack.push('#');   
 39
 40 for (i=0; i<=iLength; ) 
 41 {  
 42  chCurrent = csExp[i]; 
 43
 44  if ( JudgeOperator(csExp,i) ) //如果為操作符 
 45  {  
 46   //比較當前操作符與棧頂操作符的優先級 
 47   chTop = m_charStack.top(); 
 48   chCompareResult = QueryPri(chCurrent, chTop); 
 49     
 50
 51   switch (chCompareResult) 
 52   //根據比較結果執行不同的操作 
 53   
 54    case '>' : 
 55     //當前操作符優先級較高,壓入操作符號棧 
 56     m_charStack.push(chCurrent); 
 57     i++
 58     break
 59
 60    case '<' : 
 61     //當前操作符優先級較小,計算前面的運算結果 
 62     chMyOperator = m_charStack.top(); 
 63     m_charStack.pop(); 
 64     dbNumber2 = m_doubleStack.top(); 
 65     m_doubleStack.pop(); 
 66     dbNumber1 = m_doubleStack.top(); 
 67     m_doubleStack.pop(); 
 68     dbResult = Count(dbNumber1, dbNumber2, chMyOperator); 
 69     m_doubleStack.push(dbResult); 
 70     break
 71
 72    case '=' : 
 73     //當前操作符與棧頂操作符優先級相同,有兩種可能 
 74                    
 75     if (chCurrent==')'
 76     //如果為左右括號相遇,脫括號 
 77     
 78      m_charStack.pop(); 
 79      i++
 80      break
 81     }
//end if 
 82     else 
 83     //如果為兩個'#'相遇,運算結束 
 84     
 85      if (chCurrent=='#'
 86      {  
 87       dbResult = m_doubleStack.top(); 
 88       return dbResult; 
 89       break
 90      }
//end if 
 91
 92     }
//end else 
 93    
 94    case 'E' : 
 95     //比較出錯 
 96     break
 97      
 98    default
 99     break
100
101   }
//end switch 
102    
103   
104  }
//end if 
105  else 
106  
107   dbCurrentNumber = GetCurrentDouble(csExp,alia_i); 
108   m_doubleStack.push(dbCurrentNumber); 
109
110  }
//end else 
111    
112 }
//end for 
113
114
115 return dbResult; 
116  
117  
118
119}
;
120
121
122//對不合法的表達式,找到錯誤,通知用戶修改 
123int CCalculator::ReturnError(CString csExp) 
124{  
125 return 1
126
127}
;
128
129//查找運算符優先級 
130char CCalculator::QueryPri (char chOperator1, char chOperator2) 
131{  
132 int i = 0
133 int j = 0
134
135 switch (chOperator1) 
136 
137  case '+'
138   i = 0
139   break
140  case '-'
141   i = 1
142   break
143  case '*'
144   i = 2
145   break
146  case '/'
147   i = 3
148   break
149  case '('
150   i = 4
151   break
152  case ')'
153   i = 5
154   break
155  case '#'
156   i = 6
157   break
158  case 'e'
159   i = 7
160   break
161  default
162   break
163 }

164
165 switch (chOperator2) 
166 
167  case '+'
168   j = 0
169   break
170  case '-'
171   j = 1
172   break
173  case '*'
174   j = 2
175   break
176  case '/'
177   j = 3
178   break
179  case '('
180   j = 4
181   break
182  case ')'
183   j = 5
184   break
185  case '#'
186   j = 6
187   break
188  case  'e'
189   j = 7
190   break
191  default
192   break
193 }

194
195 return m_priTable[i][j]; 
196}

197
198//初始化運算符優先級列表 
199char CCalculator::m_priTable[8][8= 
200{  
201 //+,,,-,,,*,,,/,,,(,,,),,,#,,,e, 
202 {'<','<','<','<','>','E','>','<'},  //
203 {'<','<','<','<','>','E','>','<'}//
204 {'>','>','<','<','>','E','>','<'}//
205 {'>','>','<','<','>','E','>','<'}/// 
206 {'>','>','>','>','>','E','>','E'}//
207 {'<','<','<','<','=','E','E','<'}//
208 {'<','<','<','<','<','<','=','<'}//
209 {'>','>','>','>','>','E','>','E'}   //
210
211
212  
213}

214
215//構造函數 
216CCalculator::CCalculator(void
217{  
218 int i = 0
219
220 stack<double>::size_type double_Length; 
221 stack<char>::size_type char_Length; 
222
223
224 if (!(m_doubleStack.empty())) 
225 //初始化操作數棧 
226 {  
227  double_Length = m_doubleStack.size(); 
228
229  for (i=1; i<=double_Length; i++
230  
231   m_doubleStack.pop(); 
232  }
//end for 
233 }
//end if 
234
235  
236 if (!(m_charStack.empty())) 
237 //初始化操作符號棧 
238 {  
239  char_Length=m_charStack.size(); 
240
241  for ( i=1; i<=char_Length; i++
242  
243   m_charStack.pop(); 
244  }
//end for 
245    
246 }
//end if 
247  
248}

249
250
251
252//判斷是否為運算符 
253int CCalculator::JudgeOperator(CString csExp, int iLocation) 
254
255 switch (csExp[iLocation]) 
256 
257 case '+'
258  return 1
259  break
260 case '-'
261  if (iLocation==0
262  
263   return 0
264   break
265  }
 
266  else 
267  if ((csExp[iLocation-1]=='('|| (csExp[iLocation-1]=='e')) 
268   
269    return 0
270    break
271   }
 
272   else 
273   
274    return 1
275    break
276   }
 
277  }
 
278  return 1
279  break
280 case '*'
281  return 1
282  break
283 case '/'
284  return 1
285  break
286 case '('
287  return 1
288  break
289 case ')'
290  return 1
291  break
292 case '#'
293  return 1
294  break
295 case 'e'
296  return 1
297  break
298 default : 
299  return 0
300  break
301
302 }

303}

304
305//四則運算函數,返回結果 
306double CCalculator::Count(double dbNum1,  double dbNum2, char chOper) 
307
308 double dbResult = 0.0
309
310 switch (chOper) 
311 
312  case '+'
313   dbResult = dbNum1 + dbNum2; 
314   break
315
316  case '-'
317   dbResult = dbNum1 - dbNum2; 
318            break
319
320  case '*'
321   dbResult = dbNum1 * dbNum2; 
322   break
323
324  case '/'
325   if (!(fabs(dbNum2 - 0.0< 1e-6 )) 
326   
327    dbResult = dbNum1 / dbNum2; 
328
329   }
 
330   break
331   
332  case 'e'
333   dbResult = dbNum1 *  pow(10.0,dbNum2); 
334   break
335
336  default
337   break
338 }

339
340 return dbResult; 
341  
342}

343
344//從表達式的當前位置查找操作數并返回,當前位置向前移動 
345double CCalculator::GetCurrentDouble(CString csExpression,int& iCurrentLocation) 
346
347 int i = 0
348 int j = 0
349 int iExpressionLength = 0
350 int iELocation = 0
351 CString csDoubleString(""); 
352 char chCurrentChar = '\0'
353 double dbNumber = 0.0
354    i = iCurrentLocation; 
355  
356 iExpressionLength = csExpression.GetLength(); 
357  
358 for ( j=i+1; j<iExpressionLength; ) 
359 {  
360  chCurrentChar = csExpression[j]; 
361
362  if (!JudgeOperator(csExpression,j)) 
363  
364   j++
365
366  }
//end if 
367  else 
368  {  
369   
370   break
371
372    
373  }
//end else 
374  
375 }
//end for 
376
377 csDoubleString = csExpression.Mid(i, j-i); 
378  
379 dbNumber = atof(csDoubleString); 
380
381  
382  
383 iCurrentLocation = j; 
384
385 return dbNumber;
386
387
388}

389
390
posted on 2006-01-02 18:28 乖狗狗 閱讀(2664) 評論(7)  編輯 收藏 引用

FeedBack:
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2006-01-03 12:51 | Jonlee
我想拿來試一下,但是復制下來的文本帶有行號,刪起來很麻煩,要是直接有代碼下載就好了。  回復  更多評論
  
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2006-01-03 22:33 | 乖狗狗
To Jonlee
不好意思啊,我現在沒有有源程序提供的
我的程序只是供大家參考一下的
  回復  更多評論
  
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2006-01-10 10:27 | 過路人
用一個正則表達式就可以去掉行號了  回復  更多評論
  
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2006-02-06 15:06 | 陣雨
毛,UE和Editplus都有列選功能  回復  更多評論
  
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2006-02-12 08:28 | mi98zb
也是邊計算邊壓棧的方式呀。呵呵  回復  更多評論
  
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2006-06-14 19:59 | NET
很好啊 呵呵
我復制了 而且是逐行刪去了數字
  回復  更多評論
  
# re: 【原創】C++中用類實現支持科學計數法的四則運算器源代碼
2014-10-13 17:42 | 00000000
那么復雜啊,先用Log()計算,
小數點前的數字即為E+號后面的數字;
小數點后的部分的反對數即為"E+"號前面的數字,保留2為小數;
  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲国产高清一区| 国产拍揄自揄精品视频麻豆| 欧美一区深夜视频| 亚洲日本在线视频观看| 一区二区久久久久| 亚洲精品乱码久久久久久日本蜜臀| 亚洲韩国青草视频| 欧美一区二区三区喷汁尤物| 在线观看日产精品| 99爱精品视频| 午夜综合激情| 亚洲欧洲一区| 亚洲欧美国产高清va在线播| 日韩一级大片| 欧美一区二区在线播放| 在线精品国产欧美| 亚洲精品乱码久久久久久按摩观| 亚洲人妖在线| 久久一区二区三区国产精品 | 免费成人黄色| 国产精品国产三级国产a| 亚洲午夜91| 久久成人免费视频| 久久在线精品| 欧美日韩日韩| 欧美极品影院| 亚洲免费在线视频| 久久久综合视频| 国产毛片精品国产一区二区三区| 国产一区二区三区精品欧美日韩一区二区三区| 亚洲在线视频| 91久久综合亚洲鲁鲁五月天| 一道本一区二区| 欧美乱大交xxxxx| 亚洲精品婷婷| 亚洲精品乱码久久久久久久久| 欧美一区二区三区精品| 国产精品第一页第二页第三页| 欧美激情一区二区三区高清视频| 国产一在线精品一区在线观看| 久久国产精品久久久久久| 亚洲人成网站影音先锋播放| 制服诱惑一区二区| 久久久亚洲精品一区二区三区| 欧美亚洲视频在线观看| 激情文学一区| 日韩一区二区免费高清| 国产精品家庭影院| 久久久99国产精品免费| 美女91精品| 亚洲视频精品| 久久精品亚洲| 欧美精品福利视频| 欧美中文在线观看| 欧美一区永久视频免费观看| 欧美日韩国产首页| 亚洲国产成人高清精品| 欧美小视频在线观看| 国内精品美女在线观看| 欧美成人69av| 国产美女精品免费电影| 玖玖在线精品| 欧美日韩免费观看一区二区三区| 久久视频在线看| 一区二区三区蜜桃网| 亚洲国产天堂久久综合| 亚洲激情在线视频| 亚洲欧美激情视频| 亚洲精品欧美激情| 亚洲国产欧美一区二区三区同亚洲 | 99精品欧美| 久久免费国产| 在线成人亚洲| 亚洲欧美国产77777| 亚洲伊人网站| 国产精品外国| 亚洲国产精品成人综合| 亚洲精品美女在线| 一本色道久久综合亚洲精品不卡| 欧美不卡视频一区发布| 欧美~级网站不卡| 亚洲人成网站精品片在线观看| 欧美成人精品激情在线观看| 亚洲日本精品国产第一区| 亚洲午夜久久久久久尤物| 欧美在线日韩精品| 欧美精品一区二区三区在线播放| 亚洲人成网站色ww在线| 亚洲精品日韩一| 欧美日韩国产美女| 欧美99久久| 亚洲视频大全| 美女尤物久久精品| 亚洲伦理在线免费看| 国产精品一区二区久久久| 麻豆成人在线观看| 午夜在线视频观看日韩17c| 久久免费偷拍视频| 午夜精品久久久久久久久久久| 午夜视频久久久| 欧美华人在线视频| 你懂的网址国产 欧美| 亚洲综合精品| 久久在线免费| 麻豆视频一区二区| 久久精品国产96久久久香蕉 | 亚洲最新视频在线播放| 久久久久国产免费免费| 亚洲欧美春色| 亚洲视频自拍偷拍| 亚洲日本中文| 在线视频你懂得一区| 蜜臀a∨国产成人精品| 久久嫩草精品久久久久| 性高湖久久久久久久久| 欧美一级理论性理论a| 午夜国产不卡在线观看视频| 免费日韩av电影| 久久夜色精品国产| 欧美1级日本1级| 欧美午夜剧场| 国产亚洲激情视频在线| 亚洲国产免费看| 欧美成人免费在线| 欧美成人午夜激情在线| 亚洲视频高清| 国产精品影院在线观看| 欧美综合二区| 久久综合久久美利坚合众国| 欧美高清视频在线| 国产欧美日本一区视频| 亚洲国产成人av好男人在线观看| 久久精品男女| 亚洲人成欧美中文字幕| 欧美一区二区三区日韩| 欧美精品一区二区三区很污很色的 | 欧美88av| 亚洲欧美伊人| 久久午夜国产精品| 国产亚洲欧洲一区高清在线观看| 玖玖玖国产精品| 中文亚洲视频在线| 亚洲日本成人网| 美女啪啪无遮挡免费久久网站| 国产伦精品一区二区三区四区免费 | 国产欧美日韩一区二区三区在线观看| 国内精品久久久久影院优| 亚洲欧美在线播放| 日韩一区二区高清| 欧美日韩亚洲一区在线观看| 亚洲国产成人一区| 亚洲深夜福利| 亚洲性人人天天夜夜摸| 亚洲欧洲午夜| 国内偷自视频区视频综合| 午夜久久久久久| 夜夜精品视频一区二区| 欧美日韩在线播| 亚洲一区二区三区视频播放| 亚洲黄色成人| 欧美日韩在线影院| 国产精品一区二区男女羞羞无遮挡| 亚洲国产成人在线视频| 亚洲第一中文字幕| 欧美日韩一区二区三区视频| 日韩视频中文字幕| 欧美国产一区二区三区激情无套| 在线成人av.com| 亚洲三级电影全部在线观看高清| 欧美韩国日本综合| 欧美中文字幕| 欧美夫妇交换俱乐部在线观看| 亚洲一本大道在线| 久久久久一区| 亚洲一区欧美二区| 国产一区91精品张津瑜| 一区二区欧美日韩视频| 久久国产精品电影| 免费观看在线综合色| 久久成人精品视频| 欧美日韩国产精品专区| 另类天堂视频在线观看| 久久尤物电影视频在线观看| 亚洲免费一级电影| 中日韩在线视频| 欧美日韩在线观看视频| 亚洲国产精品福利| 亚洲国产精品传媒在线观看| 午夜精品福利一区二区三区av | 欧美一级大片在线观看| 一区二区三区免费网站| 欧美视频二区| 日韩亚洲欧美一区二区三区| 欧美国产国产综合| 美女日韩在线中文字幕| 亚洲二区三区四区| 欧美一二三区精品| 欧美在线精品免播放器视频| 国产精品99久久久久久久久| 尤物网精品视频|