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

posts - 183,  comments - 10,  trackbacks - 0

表達(dá)式的運(yùn)算

總共分兩個步驟
·中綴表達(dá)式轉(zhuǎn)換成后綴表達(dá)式
·后綴表達(dá)式的計算

中綴表達(dá)式轉(zhuǎn)換成后綴表達(dá)式:
掃描一遍中綴表達(dá)式
操作符棧
左括號和右括號的特殊性
運(yùn)算符的優(yōu)先級

后綴表達(dá)式的計算:
掃描一遍后綴表達(dá)式
操作數(shù)棧
當(dāng)前操作符,操作數(shù)棧出棧計算,注意雙目運(yùn)算符的左右順序

表達(dá)式運(yùn)算的整個過程,利用了兩個棧
·操作符棧
·操作數(shù)棧
分別應(yīng)用于第一和第二步驟中。

在做中綴表達(dá)式轉(zhuǎn)換成后綴表達(dá)式的過程中需要注意左括號和右括號的入棧出棧,其他操作符相對左括號和右括號的入棧和出棧。注意左括號的棧內(nèi)優(yōu)先級與棧外優(yōu)先級的區(qū)別。


實現(xiàn):
  1 //
  2 // 表達(dá)式運(yùn)算
  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 閱讀(169) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美视频你懂的| 亚洲视频视频在线| 免费久久久一本精品久久区| 欧美国产视频一区二区| 欧美一级视频免费在线观看| 国产免费成人在线视频| 性色av一区二区三区在线观看| 美腿丝袜亚洲色图| 久久视频这里只有精品| 国产精品久久久久久久久久久久| 99精品国产99久久久久久福利| 久久综合色一综合色88| 久久这里只有精品视频首页| 亚洲国产精品123| 亚洲黄色成人久久久| 欧美激情1区2区3区| 一区二区三区高清在线观看| 亚洲国产日韩欧美在线99| 欧美人成在线视频| 欧美诱惑福利视频| 亚洲人成人一区二区在线观看| 中国亚洲黄色| 欧美1区2区| 国产精品人成在线观看免费| 久久久噜噜噜久久| 欧美午夜宅男影院在线观看| 久久精品盗摄| 欧美午夜一区| 亚洲精品欧美日韩专区| 国内不卡一区二区三区| 亚洲一区影院| 亚洲欧美成人在线| 欧美极品欧美精品欧美视频| 久久久久久夜精品精品免费| 欧美日韩一区二区欧美激情| 欧美国产精品| 亚洲国产一区在线| 久久综合999| 亚洲国产91精品在线观看| 亚洲欧美怡红院| 午夜精品久久久久久久99黑人| 欧美无乱码久久久免费午夜一区| 国产一区91精品张津瑜| 欧美亚洲免费在线| 欧美在线二区| 欧美午夜在线一二页| 国产欧美va欧美不卡在线| 免费在线观看精品| 久久一二三国产| 欧美日韩一区二区在线| 亚洲久久一区二区| 这里只有精品丝袜| 欧美成人精品三级在线观看| 亚洲天堂男人| 亚洲视频在线一区观看| 伊人一区二区三区久久精品| 久久久噜噜噜久久狠狠50岁| 欧美日韩精品免费在线观看视频| 麻豆精品91| 经典三级久久| 欧美肥婆在线| 亚洲精品社区| 亚洲精品免费电影| 国产精品三区www17con| 久久人人爽人人爽爽久久| 久久精品在线播放| 一区二区三区在线免费视频| 亚洲一级免费视频| 欧美一区二区黄色| 国产一区二区三区网站| 蜜乳av另类精品一区二区| 乱人伦精品视频在线观看| 国产视频观看一区| 欧美在线综合| 欧美二区在线看| 亚洲欧洲日产国产网站| 欧美日韩国产精品专区| 欧美一级理论片| 欧美国产一区在线| 亚洲国产日韩一区| 国产精品视频区| 久久夜色精品国产欧美乱| 久久综合久久久久88| 伊人久久男人天堂| 欧美精品亚洲精品| 久久久久91| 一本色道久久88综合亚洲精品ⅰ| 亚洲天堂成人| 国产精品乱看| 久久亚洲免费| 亚洲一区二区黄| 91久久久国产精品| 免费国产自线拍一欧美视频| 亚洲视频在线观看免费| 亚洲日韩欧美视频一区| 激情国产一区二区| 国产精品欧美久久| 欧美国产日本在线| 久久精品72免费观看| 亚洲免费影视第一页| 在线综合视频| 91久久在线观看| 女同一区二区| 麻豆91精品91久久久的内涵| 久久女同互慰一区二区三区| 久久精品噜噜噜成人av农村| 一区二区日韩精品| 亚洲午夜精品在线| 制服丝袜激情欧洲亚洲| 在线性视频日韩欧美| 亚洲一区久久| 久久久久看片| 欧美88av| 欧美国产视频在线| 欧美大片专区| 欧美激情中文字幕乱码免费| 亚洲高清在线观看一区| 夜夜爽av福利精品导航| 亚洲欧美在线观看| 乱中年女人伦av一区二区| 欧美顶级少妇做爰| 亚洲美女av网站| 91久久一区二区| 中日韩美女免费视频网址在线观看 | 国产精品婷婷| 精品电影在线观看| 亚洲欧美日韩系列| 亚洲日韩欧美视频一区| 羞羞漫画18久久大片| 欧美日韩精品一本二本三本| 一色屋精品视频在线观看网站| 亚洲欧洲av一区二区三区久久| 欧美在线视频a| 国产精品美女主播在线观看纯欲| 亚洲国产精品悠悠久久琪琪 | 国产主播喷水一区二区| 日韩一级片网址| 免费观看成人www动漫视频| 亚洲一区二区三区四区五区黄 | 一区二区三区国产| 欧美视频精品在线| 久久久久久久久一区二区| 欧美在线视频导航| 亚洲激情电影中文字幕| 亚洲国产精品嫩草影院| 欧美激情一区二区三级高清视频 | 欧美精品在线免费| 日韩亚洲欧美精品| 99成人精品| 国产在线精品二区| 欧美激情aⅴ一区二区三区 | 亚洲欧美日韩一区二区三区在线观看| 黄色日韩网站视频| 亚洲伦理在线免费看| 国产精品私房写真福利视频| 欧美中文在线观看| 欧美激情1区2区3区| 亚洲一区欧美一区| 午夜视黄欧洲亚洲| 亚洲黄色成人网| 亚洲特黄一级片| 狠狠爱综合网| 一级日韩一区在线观看| 国外精品视频| 亚洲视频在线视频| 亚洲激情在线播放| 欧美亚洲一级片| 亚洲综合精品一区二区| 久久精品成人一区二区三区| 亚洲国产高清在线观看视频| 亚洲国产精品成人综合| 国产欧美日韩精品一区| 91久久精品视频| 国内外成人免费激情在线视频 | 亚洲欧美另类在线观看| 巨乳诱惑日韩免费av| 久久电影一区| 国产精品成av人在线视午夜片| 亚洲黄色性网站| 亚洲视频精选| 国产美女精品视频免费观看| aa亚洲婷婷| 欧美一级在线播放| 国产精品乱码久久久久久| 亚洲一区二区三区精品动漫| 久久久另类综合| 在线观看日产精品| 久久久蜜桃精品| 亚洲高清三级视频| 亚洲免费视频在线观看| 国产欧美日韩综合精品二区| 亚洲欧美日韩国产成人精品影院| 亚洲美女av黄| 欧美日韩国产欧| 一区二区福利| 久久精品国亚洲| 亚洲精品免费在线观看| 欧美午夜激情小视频| 国产精品女同互慰在线看| 亚洲免费网址|