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

誓言不會融化的那個夏天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 乖狗狗 閱讀(2663) 評論(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久久久久久白浆小说| 日韩一级精品视频在线观看| 亚洲欧美国产三级| 中国日韩欧美久久久久久久久| 日韩系列欧美系列| 久久不射中文字幕| 亚洲第一天堂av| 在线一区二区日韩| 欧美一区三区二区在线观看| 麻豆精品视频在线观看视频| 欧美三级网址| 亚洲大胆av| 午夜精品久久久99热福利| 久久亚洲影音av资源网| 日韩视频中文| 久久精品国产亚洲高清剧情介绍| 欧美高清视频一区| 国产精品家教| 亚洲大片av| 欧美制服丝袜第一页| 欧美二区不卡| 性欧美xxxx大乳国产app| 欧美了一区在线观看| 国产日韩欧美不卡在线| 一本到高清视频免费精品| 久久黄色影院| 亚洲国产二区| 久久疯狂做爰流白浆xx| 欧美视频一区二区三区| 伊人久久大香线蕉av超碰演员| 亚洲视频电影在线| 欧美99在线视频观看| 亚洲午夜一级| 欧美国产一区二区三区激情无套| 国产欧美日韩亚洲精品| 亚洲午夜激情| 亚洲欧洲综合另类| 美女久久一区| 黑丝一区二区| 欧美在线高清视频| 一区二区三区四区国产| 欧美黄色影院| 亚洲人成人99网站| 欧美成va人片在线观看| 久久久久久一区| 在线欧美影院| 美女福利精品视频| 久久久久久穴| 国产综合在线看| 久久免费黄色| 久久国产日韩欧美| 狠狠久久亚洲欧美专区| 篠田优中文在线播放第一区| 亚洲精品国产日韩| 欧美成年人视频网站欧美| 亚洲国产成人久久| 欧美一区二区高清| 亚洲午夜精品国产| 国产精品日韩在线| 免费成人毛片| 欧美人与禽猛交乱配视频| 亚洲午夜在线观看视频在线| 欧美日韩免费观看一区=区三区 | 欧美日韩成人| 亚洲免费电影在线| 亚洲精品久久视频| 欧美成人日本| 亚洲在线电影| 午夜国产不卡在线观看视频| 国产日本欧美一区二区三区在线| 欧美一区视频在线| 久久国产高清| 国产精品一区二区在线| 久久精品国产亚洲a| 美女成人午夜| 在线中文字幕日韩| 一区二区冒白浆视频| 国产精品视频久久| 久久久久久久网站| 欧美风情在线| 午夜在线播放视频欧美| 欧美在线观看一二区| 91久久黄色| 亚洲日本视频| 国产三级欧美三级日产三级99| 欧美成人精精品一区二区频| 久久综合亚州| 夜夜嗨av色一区二区不卡| 亚洲肉体裸体xxxx137| 欧美精品一区二区在线观看 | 国产午夜久久| 久久亚洲精品中文字幕冲田杏梨| 欧美.日韩.国产.一区.二区| 亚洲欧美经典视频| 毛片一区二区三区| 亚洲日本va午夜在线电影 | 你懂的网址国产 欧美| 伊大人香蕉综合8在线视| 欧美激情一区二区三区蜜桃视频| 欧美视频成人| 久久这里有精品15一区二区三区| 欧美成人网在线| 亚洲欧美视频一区| 久久一日本道色综合久久| 亚洲伊人第一页| 久久一区二区精品| 亚洲婷婷免费| 欧美sm视频| 麻豆久久久9性大片| 国产免费亚洲高清| 一区二区三区色| 亚洲国产成人久久综合| 午夜视频在线观看一区二区| 亚洲国产91精品在线观看| 亚洲国产日韩一区二区| 国产精品久久久久久久久久免费| 国产色综合天天综合网| 欧美激情一区二区三区| 国产精品亚洲精品| 99精品免费| 亚洲美女一区| 免费在线国产精品| 狂野欧美一区| 最新国产成人在线观看| 黄色国产精品| 亚洲欧美中文日韩v在线观看| 99在线观看免费视频精品观看| 女同一区二区| 亚洲精品激情| 亚洲欧洲一区二区三区在线观看| 久久一区中文字幕| 久久综合久久综合久久| 国产精品另类一区| 亚洲一区二区3| 欧美在线播放一区| 国产午夜精品美女视频明星a级 | 免费不卡在线观看av| 欧美丰满高潮xxxx喷水动漫| 亚洲国产精品电影| 欧美a级一区| 日韩视频免费大全中文字幕| 亚洲视频一区| 国产欧美91| 久久尤物视频| 亚洲精品在线一区二区| 亚洲免费视频网站| 国产亚洲人成a一在线v站| 久久在线播放| 日韩视频在线观看一区二区| 亚洲免费一级电影| 海角社区69精品视频| 久久一区二区视频| 亚洲理论在线观看| 亚洲性色视频| 国内精品嫩模av私拍在线观看| 久久―日本道色综合久久| 亚洲美女诱惑| 久久久午夜视频| 日韩一级不卡| 国产自产v一区二区三区c| 欧美激情亚洲精品| 亚洲欧美另类在线| 欧美国产视频在线观看| 午夜亚洲福利在线老司机| 亚洲第一网站| 欧美特黄一级| 久久久久久久性| 黄色在线一区| 欧美日韩在线精品| 久久综合激情| 亚洲欧美日韩成人高清在线一区| 欧美va亚洲va国产综合| 亚洲欧美另类在线观看| 曰韩精品一区二区| 国产精品日韩二区| 欧美国产大片| 久久深夜福利| 欧美一区二区啪啪| 9国产精品视频| 亚洲高清免费| 葵司免费一区二区三区四区五区| 99精品国产热久久91蜜凸| 国产在线高清精品| 国产精品视频久久| 欧美日韩福利| 国产免费观看久久| 久久久免费av| 亚洲性夜色噜噜噜7777| 亚洲国产精品一区制服丝袜| 欧美资源在线观看| 一本久久知道综合久久| 91久久精品国产| 亚洲二区精品| 激情亚洲成人| 国产日韩欧美在线观看| 国产精品视频第一区|