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

posts - 183,  comments - 10,  trackbacks - 0

表達式的運算

總共分兩個步驟
·中綴表達式轉換成后綴表達式
·后綴表達式的計算

中綴表達式轉換成后綴表達式:
掃描一遍中綴表達式
操作符棧
左括號和右括號的特殊性
運算符的優先級

后綴表達式的計算:
掃描一遍后綴表達式
操作數棧
當前操作符,操作數棧出棧計算,注意雙目運算符的左右順序

表達式運算的整個過程,利用了兩個棧
·操作符棧
·操作數棧
分別應用于第一和第二步驟中。

在做中綴表達式轉換成后綴表達式的過程中需要注意左括號和右括號的入棧出棧,其他操作符相對左括號和右括號的入棧和出棧。注意左括號的棧內優先級與棧外優先級的區別。


實現:
  1 //
  2 // 表達式運算
  3 // Mark
  4 // email: goonyangxiaofang AT 163.com
  5 // QQ   : 591247876
  6 // 2011.6.29
  7 // ( ( 1 + 2 ) * 3 + ( 1 + 10 ) ) / 2
  8 // ???
  9 //
 10 
 11 #include <iostream>
 12 #include <string>
 13 #include <vector>
 14 #include <stack>
 15 #include <map>
 16 #include <cstdlib>
 17 using namespace std;
 18 
 19 map<stringint> operatorPriors;
 20 
 21 void getInfix(vector<string>& infix)
 22 {
 23     infix.clear();
 24     string tmp;
 25     while (cin >> tmp)
 26     {
 27         infix.push_back(tmp);
 28     }
 29 }
 30 
 31 void init()
 32 {
 33     operatorPriors["+"= 10;
 34     operatorPriors["-"= 10;
 35     operatorPriors["*"= 20;
 36     operatorPriors["/"= 20;
 37     operatorPriors["%"= 20;
 38     operatorPriors["("= 30;
 39     operatorPriors[")"= 0;
 40 }
 41 
 42 bool prior(const string& op1, const string& op2)
 43 {
 44     return operatorPriors[op1] > operatorPriors[op2];
 45 }
 46 
 47 bool isOperator(const string& s)
 48 {
 49     return operatorPriors.find(s) != operatorPriors.end();
 50 }
 51 
 52 void print(stack<string> operators)
 53 {
 54     while (!operators.empty())
 55     {
 56         cout << operators.top() << ' ';
 57         operators.pop();
 58     }
 59     cout << endl;
 60 }
 61 
 62 const vector<string>& infixToPostfix(vector<string>& postfix, const vector<string>& infix)
 63 {
 64     postfix.clear();
 65     stack<string> operators;
 66     for (vector<string>::size_type i = 0; i != infix.size(); ++i)
 67     {
 68         if (isOperator(infix[i]))
 69         {
 70             if (operators.empty())
 71             {
 72                 operators.push(infix[i]);
 73             }
 74             else if (operators.top() == "(" && infix[i] != ")" || prior(infix[i], operators.top()))
 75             {
 76                 operators.push(infix[i]);
 77             }
 78             else
 79             {
 80                 if (infix[i] == ")")
 81                 {
 82                     while (operators.top() != "(")
 83                     {
 84                         postfix.push_back(operators.top());
 85                         operators.pop();
 86                     }
 87                     operators.pop();
 88                 }
 89                 else
 90                 {
 91                     postfix.push_back(operators.top());
 92                     operators.pop();
 93                     while (!operators.empty() && !prior(infix[i], operators.top()) && operators.top() != "(")
 94                     {
 95                         postfix.push_back(operators.top());
 96                         operators.pop();
 97                     }
 98                     
 99                     operators.push(infix[i]);
100                 }
101             }
102         }
103         else
104         {
105             postfix.push_back(infix[i]);
106         }
107     }
108     while (!operators.empty())
109     {
110         postfix.push_back(operators.top());
111         operators.pop();
112     }
113     return postfix;
114 }
115 
116 double stringToDouble(const string& s)
117 {
118     return (atof(s.c_str()));
119 }
120 
121 double evalPost(const vector<string>& post)
122 {
123     stack<double> operands;
124     int a, b;
125     for (vector<string>::size_type i = 0; i != post.size(); ++i)
126     {
127         if (post[i] == "+")
128         {
129             b = operands.top();
130             operands.pop();
131             a = operands.top();
132             operands.pop();
133             operands.push(a + b);
134         }
135         else if (post[i] == "-")
136         {
137             b = operands.top();
138             operands.pop();
139             a = operands.top();
140             operands.pop();
141             operands.push(a - b);
142         }
143         else if (post[i] == "*")
144         {
145             b = operands.top();
146             operands.pop();
147             a = operands.top();
148             operands.pop();
149             operands.push(a * b);
150         }
151         else if (post[i] == "/")
152         {
153             b = operands.top();
154             operands.pop();
155             a = operands.top();
156             operands.pop();
157             operands.push(a / b);
158         }
159         else if (post[i] == "%")
160         {
161             b = operands.top();
162             operands.pop();
163             a =operands.top();
164             operands.pop();
165             operands.push(a - b);
166         }
167         else
168         {
169             // stringstream ss;
170             // ss << post[i];
171             // ss >> a;
172             operands.push(stringToDouble(post[i]));
173         }
174     }
175     return operands.top();
176 }
177 
178 int main()
179 {
180     init();
181     vector<string> infix;
182     vector<string> postfix;
183     getInfix(infix);
184     infixToPostfix(postfix, infix);
185     for (vector<string>::size_type i = 0; i != postfix.size(); ++i)
186     {
187         cout << postfix[i] << ' ';
188     }
189     cout << endl;
190     cout << evalPost(postfix) << endl;
191     return 0;
192 }


posted on 2011-06-29 01:58 unixfy 閱讀(166) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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视频一区| 黄色亚洲在线| 亚洲一区二区三区中文字幕| 免费h精品视频在线播放| 宅男66日本亚洲欧美视频| 免费观看30秒视频久久| 国产欧美精品一区aⅴ影院| 亚洲永久免费av| 亚洲视频免费| 国产精品va在线| 亚洲一级免费视频| 亚洲先锋成人| 午夜日韩在线| 亚洲午夜极品| 国产精品午夜av在线| 日韩西西人体444www| 亚洲大片在线观看| 欧美精品激情| 香蕉视频成人在线观看| 欧美在线资源| 激情成人av在线| 麻豆国产精品777777在线| 久久精品二区亚洲w码| 亚洲国产裸拍裸体视频在线观看乱了中文 | 午夜精品久久| 国产情侣一区| 你懂的一区二区| 欧美国产一区二区在线观看| 在线亚洲精品| 午夜精品久久久久久久男人的天堂| 国产午夜精品理论片a级探花| 蜜桃av噜噜一区| 欧美日韩91| 久久成人18免费网站| 久久综合一区二区| 一区二区三区日韩在线观看| 亚洲在线视频| 亚洲国产精选| 亚洲一区二区三区在线观看视频| 国产一区二区成人久久免费影院| 女人香蕉久久**毛片精品| 欧美美女日韩| 久久久综合网| 欧美午夜精品久久久久久久| 久久久夜夜夜| 国产精品chinese| 欧美chengren| 国产精品亚发布| 欧美激情国产日韩| 国产精品欧美久久久久无广告| 老鸭窝毛片一区二区三区| 欧美日韩国产一区二区三区地区| 久久久久久91香蕉国产| 欧美另类99xxxxx| 久久人人爽人人爽| 国产精品久久久久久妇女6080 | 欧美国产日韩一区二区在线观看| 国产精品二区在线| 亚洲动漫精品| 韩国一区二区三区在线观看| 日韩网站在线| 亚洲国产综合在线看不卡| 亚洲中字在线| 一区二区三区精品视频在线观看| 艳妇臀荡乳欲伦亚洲一区| 亚洲丁香婷深爱综合| 国产性做久久久久久| 亚洲精品久久久久久久久久久| 国内精品久久久久伊人av| 在线亚洲欧美视频| 亚洲精品裸体| 噜噜噜噜噜久久久久久91| 久久精品国产免费| 国产精品美女www爽爽爽视频| 亚洲激情国产精品| 亚洲国产高清自拍| 久久精品视频导航| 欧美自拍偷拍午夜视频| 国产精品sm| 99精品国产福利在线观看免费| 91久久在线视频| 老司机午夜免费精品视频| 米奇777在线欧美播放| 一区在线影院| 久久久噜噜噜| 欧美成人国产一区二区| 亚洲第一中文字幕| 玖玖国产精品视频| 欧美福利小视频| 亚洲欧洲日产国码二区| 欧美激情在线有限公司| 亚洲人成免费| 国产精品99久久久久久久女警| 欧美女激情福利| 日韩亚洲视频| 亚洲欧美综合网| 国产乱码精品一区二区三区五月婷 | 亚洲主播在线| 欧美一区二区三区免费大片| 国产九九精品| 久久九九免费视频| 欧美大片网址| 亚洲免费精彩视频| 欧美日韩另类字幕中文| 亚洲无人区一区| 久久精品欧美| 亚洲国产精品精华液网站| 欧美激情视频在线免费观看 欧美视频免费一| 欧美高清在线观看| 一区二区av在线| 国产精品视频久久| 久久久www成人免费无遮挡大片| 欧美1级日本1级| 99在线热播精品免费99热| 国产精品乱子久久久久| 久久精品午夜| 亚洲精品在线一区二区| 性欧美18~19sex高清播放| 好吊日精品视频| 欧美国产日韩a欧美在线观看| 一本一本久久| 老巨人导航500精品| 99视频超级精品| 国产一二三精品| 欧美乱大交xxxxx| 欧美一区1区三区3区公司| 亚洲第一精品电影| 亚洲国产第一| 极品裸体白嫩激情啪啪国产精品| 欧美一区日韩一区| 最新日韩中文字幕| 久久精品国产综合精品| 日韩午夜精品视频| 国产在线播精品第三| 欧美精品麻豆| 久久精品女人天堂| 亚洲一级片在线看| 亚洲国产三级| 久热国产精品视频| 翔田千里一区二区| 99爱精品视频| 激情综合色丁香一区二区| 国产精品国产三级国产专播精品人| 久久亚洲私人国产精品va| 亚洲一区二三| 亚洲人在线视频| 欧美成人乱码一区二区三区| 欧美亚洲在线播放| 一区二区免费看| 亚洲人成网站在线播| 国产在线欧美| 国产精品制服诱惑| 欧美日本中文| 欧美成人一区二区在线| 久久久精品国产免大香伊| 亚洲综合电影| 在线一区二区三区做爰视频网站| 亚洲黄色免费电影| 欧美xxxx在线观看| 久久中文字幕一区二区三区| 欧美在线精品免播放器视频| 亚洲直播在线一区| 这里只有精品丝袜| 一区二区久久| 亚洲午夜在线观看| 亚洲午夜国产一区99re久久| 日韩亚洲综合在线| 亚洲国产欧美一区二区三区久久| 国产主播一区二区三区四区| 国产女优一区| 国产精品夜夜夜| 国产日韩欧美高清| 国产婷婷色一区二区三区在线| 国产精品呻吟| 国产精品永久免费观看| 国产伦精品一区二区三区视频黑人 | 黄色小说综合网站| 激情国产一区| 亚洲第一精品福利| 亚洲人成亚洲人成在线观看图片| 亚洲精品久久久久久久久久久久久| 亚洲福利视频一区| 亚洲欧洲日产国产网站| av不卡免费看| 亚洲——在线| 欧美一站二站| 久久青草久久| 欧美激情国产日韩精品一区18| 欧美成人激情视频| 亚洲黄色有码视频| 亚洲视频一区| 久久aⅴ国产欧美74aaa| 久久午夜精品一区二区| 欧美精品一区二| 国产精品久久久久久久7电影| 国产视频观看一区| 亚洲激情在线视频| 亚洲图片欧洲图片av| 欧美一区=区|