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

posts - 183,  comments - 10,  trackbacks - 0

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

這里利用的棧是操作符棧
在計算后綴表達式的過程中,利用的棧是操作數棧
從中綴表達式轉換為后綴表達式也是一遍掃描中綴表達式即可,當然中間涉及對操作符棧的操作。

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

實現:

 

  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)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            亚洲影院免费| 久久久www成人免费精品| 99国产精品久久久久久久| 亚洲人体偷拍| 香蕉久久夜色精品国产使用方法| 久久高清免费观看| 亚洲激情偷拍| 久久深夜福利免费观看| 欧美亚男人的天堂| 亚洲人成在线播放网站岛国| 久久精品夜夜夜夜久久| 日韩一二三区视频| 久久亚洲精品一区| 日韩亚洲国产欧美| 欧美激情综合在线| 日韩午夜在线播放| 久久综合亚州| 欧美jizzhd精品欧美巨大免费| 日韩西西人体444www| 久久久青草青青国产亚洲免观| 亚洲综合99| 狠狠入ady亚洲精品经典电影| 久久大逼视频| 久久久久女教师免费一区| 国产在线观看91精品一区| 久久九九精品99国产精品| 欧美一级日韩一级| 亚洲国产高清在线| 99精品99| 亚洲激情视频网| 亚洲一区二区精品视频| 国产一区二区在线观看免费播放| 久久综合一区二区| 欧美精品导航| 久久亚洲精品网站| 国产精品日韩在线播放| 欧美电影打屁股sp| 国产伦精品一区二区三区视频孕妇 | 一区二区三区亚洲| 亚洲九九爱视频| 国产一区二区三区直播精品电影| 亚洲国产福利在线| 亚洲精品国产精品国自产观看浪潮| 黄色精品一区二区| 久久久久久久国产| 欧美日韩在线免费视频| 欧美国产国产综合| 国产欧美日韩一区| 亚洲欧美一区二区原创| 亚洲视频久久| 欧美精品一区二区高清在线观看| 久久午夜国产精品| 狠狠色狠狠色综合日日tαg| 99视频在线精品国自产拍免费观看| 狠狠爱成人网| 日韩视频―中文字幕| 一区二区三区欧美在线观看| 一区国产精品| 欧美va天堂| 日韩网站在线观看| 亚洲欧美bt| 久久大综合网| 久久久av水蜜桃| 亚洲国产视频一区二区| 欧美gay视频| 一本色道久久综合亚洲精品按摩| 亚洲天堂免费观看| 国语自产偷拍精品视频偷| 久久视频免费观看| 一区二区三区免费观看| 亚洲欧美中文字幕| 国产亚洲一区二区三区在线观看| 久久都是精品| 亚洲开发第一视频在线播放| 新狼窝色av性久久久久久| 国产一区再线| 欧美性做爰猛烈叫床潮| 久久免费视频在线观看| 亚洲九九精品| 国内精品国产成人| 欧美高清日韩| 欧美一区永久视频免费观看| 欧美国产大片| 老司机精品视频网站| 最新国产の精品合集bt伙计| 性久久久久久久久| 中日韩午夜理伦电影免费| 好吊妞**欧美| 国产视频精品va久久久久久| 欧美区亚洲区| 欧美黄色大片网站| 久久久国产一区二区| 亚洲一区二区免费在线| 欧美视频中文字幕在线| 亚洲女女女同性video| 国产美女高潮久久白浆| 欧美日韩中文字幕日韩欧美| 久久综合久久综合这里只有精品| 亚洲一区在线观看视频 | 亚洲欧洲精品一区二区三区不卡 | 一本色道88久久加勒比精品| 国产日韩欧美麻豆| 国产欧美一区二区三区久久人妖| 欧美激情国产精品| 欧美视频在线观看免费网址| 欧美日韩成人一区二区| 欧美金8天国| 国产精品第一区| 国产亚洲毛片| 亚洲靠逼com| 一区二区三区欧美在线观看| 亚洲小视频在线| 欧美成在线观看| 亚洲第一天堂无码专区| 欧美一区二区三区在线视频| 欧美日韩亚洲一区在线观看| 亚洲国产日日夜夜| 久久婷婷av| 久久久夜精品| 国语自产在线不卡| 久久精品免费播放| 午夜精品一区二区三区电影天堂| 欧美久久一级| 中文欧美字幕免费| 亚洲免费高清视频| 欧美日韩亚洲一区在线观看| 夜夜嗨av一区二区三区中文字幕| 欧美福利一区| 欧美激情综合五月色丁香| 一本色道久久88综合日韩精品| 久久av一区二区三区漫画| 国产精品美女久久久| 久久gogo国模裸体人体| 翔田千里一区二区| 国产精品入口夜色视频大尺度 | 欧美日韩免费网站| 欧美一级在线视频| 久久久久久夜| 亚洲图片欧美一区| 亚洲性感美女99在线| 国产亚洲精品aa| 亚洲人在线视频| 国产日产亚洲精品| 亚洲七七久久综合桃花剧情介绍| 国产精品盗摄久久久| 欧美成人精品高清在线播放| 欧美ed2k| 久久裸体视频| 国产精品毛片va一区二区三区| 欧美成人官网二区| 99re6热在线精品视频播放速度| 亚洲一区二区三区免费在线观看| 一区免费观看| 亚洲一区综合| 一区二区三区四区国产精品| 香蕉久久夜色精品国产| 欧美久色视频| 另类国产ts人妖高潮视频| 国产精品毛片a∨一区二区三区| 欧美成人精品| 亚洲高清不卡| 美国十次成人| 欧美高清一区| 在线精品在线| 久久综合九色| 亚洲韩国青草视频| 亚洲激情在线激情| 久久精品国产亚洲一区二区三区| 午夜精品福利视频| 国产精品婷婷| 欧美亚洲免费| 玖玖玖国产精品| 亚洲黄网站在线观看| 欧美国产在线电影| 一区二区免费看| 亚洲欧美在线x视频| 国产日韩欧美不卡在线| 亚洲欧美日本国产有色| 欧美一区二区三区精品| 激情综合色丁香一区二区| 麻豆91精品| 日韩视频一区二区在线观看| 亚洲视频免费在线观看| 国产精品毛片| 麻豆国产精品va在线观看不卡| 欧美激情二区三区| 西瓜成人精品人成网站| 亚洲第一黄色网| 国产精品羞羞答答| 欧美成人在线网站| 欧美一区二区视频在线观看| 蜜乳av另类精品一区二区| 一区二区三区国产精华| 国产性做久久久久久| 欧美另类在线播放| 噜噜噜噜噜久久久久久91| 亚洲综合色视频| 夜夜嗨av一区二区三区四区| 欧美1区2区| 可以免费看不卡的av网站|