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

posts - 183,  comments - 10,  trackbacks - 0

中綴表達(dá)式轉(zhuǎn)換為后綴表達(dá)式
在表達(dá)式計(jì)算中,第一要做的就是講中綴表達(dá)式轉(zhuǎn)換成后綴表達(dá)式
所采用的方式是,掃描中綴表達(dá)式,檢測每個(gè)中綴表達(dá)式的元素
如果是操作數(shù),則將其加入到輸出的后綴表達(dá)式中
如果是操作符,需要對其分析,設(shè)定一個(gè)操作符棧,
·如果一開始操作符棧為空,則將該操作符壓棧
·這里涉及左括號的兩個(gè)優(yōu)先級,即棧外優(yōu)先級和棧內(nèi)優(yōu)先級,如果左括號在棧外,則其優(yōu)先級最高,直接將其壓入到操作符棧中,如果左括號在棧內(nèi),則其優(yōu)先級很低,只有在碰到右括號的時(shí)候才會(huì)彈棧,遇到其他運(yùn)算符時(shí),直接當(dāng)其他運(yùn)算符壓棧。
·這里涉及操作符優(yōu)先級問題,+ - * / % 這里的優(yōu)先級相對于壓操作符棧的優(yōu)先級。即檢測當(dāng)前操作符與棧頂?shù)牟僮鞣麅?yōu)先級,如果當(dāng)前操作符優(yōu)先級高于棧頂操作符優(yōu)先級,需要將當(dāng)前操作符壓棧,如果當(dāng)前操作符優(yōu)先級小于或等于棧頂操作符優(yōu)先級,則將棧頂操作符出棧,然后再次檢測下一個(gè)棧頂操作符的優(yōu)先級與當(dāng)前操作符優(yōu)先級關(guān)系。
·對于有左括號和右括號的情況,需要對其做特殊分析。左括號會(huì)被壓入棧中,右括號不會(huì)。如果當(dāng)前元素時(shí)左括號,由于其棧外優(yōu)先級最高,可以直接將其壓入棧中,如果棧頂優(yōu)先級是左括號,并且當(dāng)前操作符是一般操作符,則直接將當(dāng)前操作符壓入棧中,如果當(dāng)前操作符是右括號,則直接將棧頂?shù)淖罄ㄌ柍鰲!?br />·中綴表達(dá)式和后綴表達(dá)式的不同是操作符的相對位置存在變化,當(dāng)然后綴表達(dá)式不會(huì)出現(xiàn)括號,也就是后綴表達(dá)式中隱式包含了操作符的優(yōu)先級。另外中綴和后綴表達(dá)式中的操作數(shù)相對順序是一致的,在轉(zhuǎn)換的過程中,當(dāng)當(dāng)前中綴表達(dá)式中的元素時(shí)操作數(shù)時(shí),直接將其添加到輸出后綴表達(dá)式中就可以。

這里利用的棧是操作符棧
在計(jì)算后綴表達(dá)式的過程中,利用的棧是操作數(shù)棧
從中綴表達(dá)式轉(zhuǎn)換為后綴表達(dá)式也是一遍掃描中綴表達(dá)式即可,當(dāng)然中間涉及對操作符棧的操作。

修正:( ( 1 + 2 ) * 3 + ( 1 + 10 ) ) / 2 , ( ( ( 1 + 2 + 3 ) ) ) 的情形。要時(shí)刻考慮到括號的特殊性,左括號的棧內(nèi)優(yōu)先級和棧外優(yōu)先級的區(qū)別。對于左括號和右括號的主動(dòng)入棧和出棧以及其他操作符的相對于其入棧和出棧決策要考慮清楚。

實(shí)現(xiàn):

 

  1 #include <iostream>
  2 #include <string>
  3 #include <vector>
  4 #include <stack>
  5 #include <map>
  6 using namespace std;
  7 
  8 map<stringint> operatorPriors;
  9 
 10 void getInfix(vector<string>& infix)
 11 {
 12     infix.clear();
 13     string tmp;
 14     while (cin >> tmp)
 15     {
 16         infix.push_back(tmp);
 17     }
 18 }
 19 
 20 void init()
 21 {
 22     operatorPriors["+"= 10;
 23     operatorPriors["-"= 10;
 24     operatorPriors["*"= 20;
 25     operatorPriors["/"= 20;
 26     operatorPriors["%"= 20;
 27     operatorPriors["("= 30;
 28     operatorPriors[")"= 0;
 29 }
 30 
 31 bool prior(const string& op1, const string& op2)
 32 {
 33     return operatorPriors[op1] > operatorPriors[op2];
 34 }
 35 
 36 bool isOperator(const string& s)
 37 {
 38     return operatorPriors.find(s) != operatorPriors.end();
 39 }
 40 
 41 void print(stack<string> operators)
 42 {
 43     while (!operators.empty())
 44     {
 45         cout << operators.top() << ' ';
 46         operators.pop();
 47     }
 48     cout << endl;
 49 }
 50 
 51 const vector<string>& infixToPostfix(vector<string>& postfix, const vector<string>& infix)
 52 {
 53     postfix.clear();
 54     stack<string> operators;
 55     for (vector<string>::size_type i = 0; i != infix.size(); ++i)
 56     {
 57         if (isOperator(infix[i]))
 58         {
 59             if (operators.empty())
 60             {
 61                 operators.push(infix[i]);
 62             }
 63             else if (operators.top() == "(" && infix[i] != ")" || prior(infix[i], operators.top()))
 64             {
 65                 operators.push(infix[i]);
 66             }
 67             else
 68             {
 69                 if (infix[i] == ")")
 70                 {
 71                     while (operators.top() != "(")
 72                     {
 73                         postfix.push_back(operators.top());
 74                         operators.pop();
 75                     }
 76                     operators.pop();
 77                 }
 78                 else
 79                 {
 80                     postfix.push_back(operators.top());
 81                     operators.pop();
 82                     while (!operators.empty() && !prior(infix[i], operators.top()) && operators.top() != "(")
 83                     {
 84                         postfix.push_back(operators.top());
 85                         operators.pop();
 86                     }
 87                     
 88                     operators.push(infix[i]);
 89                 }
 90             }
 91         }
 92         else
 93         {
 94             postfix.push_back(infix[i]);
 95         }
 96     }
 97     while (!operators.empty())
 98     {
 99         postfix.push_back(operators.top());
100         operators.pop();
101     }
102     return postfix;
103 }
104 
105 int main()
106 {
107     init();
108     vector<string> infix;
109     vector<string> postfix;
110     getInfix(infix);
111     infixToPostfix(postfix, infix);
112     for (vector<string>::size_type i = 0; i != postfix.size(); ++i)
113     {
114         cout << postfix[i] << ' ';
115     }
116     cout << endl;
117     return 0;
118 }


posted on 2011-06-29 01:07 unixfy 閱讀(583) 評論(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>
            国产综合色精品一区二区三区| 裸体丰满少妇做受久久99精品| 亚洲高清一区二区三区| 你懂的视频一区二区| 一本色道久久综合亚洲精品高清 | 美国成人毛片| 久久精品九九| 老色批av在线精品| 久热国产精品| 亚洲欧洲在线观看| 99精品国产在热久久婷婷| 欧美第一黄网免费网站| 亚洲成人中文| 亚洲人成在线播放网站岛国| 亚洲国产成人午夜在线一区| 欧美高清成人| 9人人澡人人爽人人精品| 日韩性生活视频| 欧美一区二区三区视频在线观看| 久久精精品视频| 欧美韩日一区| 国内精品嫩模av私拍在线观看 | 亚洲成色精品| 日韩亚洲综合在线| 久久精品国产91精品亚洲| 欧美 日韩 国产一区二区在线视频| 亚洲福利av| 久久精品网址| 国产欧美精品国产国产专区| 99精品福利视频| 亚洲最新色图| 免费不卡亚洲欧美| 国产精品爽爽爽| 国产亚洲毛片在线| 这里只有精品在线播放| 久久综合99re88久久爱| 亚洲欧美日韩精品久久亚洲区| 欧美国产日产韩国视频| 一区免费视频| 欧美成人激情在线| 久久久久久一区二区三区| 欧美精品乱人伦久久久久久| 精久久久久久| 欧美mv日韩mv国产网站| 久久国内精品自在自线400部| 国产精品婷婷午夜在线观看| 午夜亚洲精品| 久久激情婷婷| 亚洲精品美女免费| 亚洲精品乱码久久久久久蜜桃麻豆| 久久精品导航| 亚洲美女尤物影院| 9l视频自拍蝌蚪9l视频成人| 欧美日韩精品一区二区天天拍小说 | 亚洲免费高清| 国产精品一区二区久激情瑜伽| 亚洲一区精品电影| 性视频1819p久久| 一本色道久久综合亚洲精品小说| 性做久久久久久| 国模套图日韩精品一区二区| 久久9热精品视频| 噜噜噜久久亚洲精品国产品小说| 亚洲国产精品va在看黑人| 久久一区激情| 欧美一级免费视频| 猫咪成人在线观看| 香蕉精品999视频一区二区| 久久成人18免费网站| 亚洲一区免费看| 欧美日韩精品中文字幕| 欧美r片在线| 激情欧美日韩| 久久国产精品亚洲va麻豆| 亚洲欧美在线磁力| 欧美视频在线一区| 亚洲乱码国产乱码精品精98午夜| 黑人巨大精品欧美一区二区| 中文国产成人精品| 亚洲免费一在线| 国产精品xvideos88| 一本久道久久久| 亚洲自拍啪啪| 国产精品久久久久毛片大屁完整版 | 欧美xx视频| 亚洲人成网站色ww在线| 日韩视频在线永久播放| 久久先锋影音av| 国产又爽又黄的激情精品视频| 亚洲欧美视频在线| 久久精品成人欧美大片古装| 国产综合视频| 蜜臀av性久久久久蜜臀aⅴ| 亚洲第一搞黄网站| 亚洲天堂黄色| 国语自产偷拍精品视频偷| 久久午夜电影| 亚洲一区二区免费看| 久久午夜精品| av成人免费在线| 一区二区三区在线免费播放| 欧美精品大片| 亚洲一区免费视频| 亚洲国产美国国产综合一区二区| 一本到高清视频免费精品| 亚洲精品欧美专区| 亚洲网站视频福利| 亚洲第一视频| 国产综合视频| 国内自拍视频一区二区三区| 欧美精品电影在线| 另类人畜视频在线| 欧美一区二区三区在线观看视频| 亚洲三级影片| 亚洲精品九九| 亚洲人屁股眼子交8| 欧美电影美腿模特1979在线看| 亚洲欧美日韩国产一区二区| 日韩视频中文字幕| 在线亚洲+欧美+日本专区| 亚洲国产精品欧美一二99| 激情婷婷久久| 91久久精品国产91性色| 亚洲精品久久久久久下一站| 亚洲黄一区二区三区| 99精品国产热久久91蜜凸| 免费亚洲一区| 美女诱惑黄网站一区| 老司机午夜精品视频| 欧美精品一区二区三区蜜臀 | 亚洲一区国产一区| 欧美一区二区三区免费大片| 欧美有码在线观看视频| 欧美福利视频在线| 99热免费精品在线观看| 午夜精品久久久久久久99热浪潮| 久久久精品一区| 欧美精品精品一区| 国产精品国产亚洲精品看不卡15| 国产欧美日韩中文字幕在线| 亚洲国产专区| 久久精品成人一区二区三区蜜臀 | 欧美一区二区三区视频在线观看| 久久精品国产2020观看福利| 久久影院午夜论| 先锋影音国产一区| 欧美日韩一区综合| 妖精视频成人观看www| 欧美大学生性色视频| 性色av一区二区三区红粉影视| 欧美另类视频| 日韩亚洲精品电影| 亚洲国产日韩精品| 久久麻豆一区二区| 精品999成人| 久久久久久亚洲精品杨幂换脸| 亚洲欧洲在线一区| 一本大道久久a久久精品综合| 欧美刺激性大交免费视频| 午夜欧美不卡精品aaaaa| 国产精品电影网站| 亚洲一区久久久| 亚洲一品av免费观看| 国产精品久久一区主播| 亚洲在线1234| 亚洲一区免费视频| 一本久道综合久久精品| 欧美午夜无遮挡| 久久精品成人一区二区三区| 久久激情五月激情| 99精品视频免费在线观看| 亚洲人成在线播放| 国产日韩欧美一区二区三区四区| 久久久久国产精品一区二区| 久久久之久亚州精品露出| 99视频在线观看一区三区| 亚洲小说春色综合另类电影| 国内精品视频久久| aa国产精品| 91久久精品日日躁夜夜躁国产| 99re66热这里只有精品4| 国产一区二区视频在线观看 | 亚洲国产一区在线观看| 日韩视频一区二区三区在线播放免费观看 | 亚洲国产一区在线观看| 亚洲欧美日韩一区在线观看| 亚洲欧洲精品一区| 亚洲永久视频| 亚洲影音一区| 欧美日韩亚洲成人| 亚洲人成网在线播放| 国产真实乱偷精品视频免| 99re66热这里只有精品4 | 裸体一区二区| 欧美在线首页| 国产欧美一区二区三区沐欲 | 欧美在线视频二区| 国产精品99免视看9| 日韩视频一区二区三区在线播放| 亚洲人屁股眼子交8|