逆波蘭表達式介紹

1栅受、概念

逆波蘭表示法也叫后綴表示法,即操作符號都置于操作數(shù)的后面塔淤,逆波蘭表示法可以不用括號來標識操作符的優(yōu)先級阱飘。例如:3+4 是一個中綴表達式斥杜,轉(zhuǎn)換成逆波蘭表達式為34+ 。有人可能會想有后綴表達式沥匈,中綴表達式蔗喂,那有沒有前綴表達式呢?答案是:有前綴表達式咐熙,也叫波蘭表達式,上文中的3+4 用前綴表達式表示為+34辨萍。

2棋恼、用途

1.逆波蘭表達式中不需要括號,用戶只需按照表達式順序求值锈玉,讓堆棧自動記錄中間結(jié)果爪飘;同樣的,也不需要指定操作符的優(yōu)先級
2.機器狀態(tài)永遠是一個堆棧狀態(tài)拉背,堆棧里是需要運算的操作數(shù)师崎,棧內(nèi)不會有操作符。
3.當有操作符時就計算椅棺,因此犁罩,表達式并不是從右至左整體計算而是每次由中心向外計算一部分,這樣在復雜運算中就很少導致操作符錯誤两疚。

3床估、計算原理

逆波蘭表達式進行數(shù)據(jù)計算的時候一般分為兩步:
1.將中綴表達式轉(zhuǎn)換為后綴表達式
2.對轉(zhuǎn)換完成后的后綴表達式進行計算

例子:我們以a+b-c*(d+e) 來進行分析

3.1 將其轉(zhuǎn)換為后綴表達式

.首先我們要建立一個集合 sList 來存放例子中的數(shù)據(jù)和操作符號,一個棧opStack來存放中間的操作符號诱渤,一個集合dList 來存放最后的轉(zhuǎn)換結(jié)果丐巫。
2.從sList中取出一個元素A然后進行以下判斷:
1.如果A是數(shù)字,則直接存如dList
2.如果A是運算符勺美,則和opStack棧頂?shù)脑剡M行運算優(yōu)先級比較
1.如果A的優(yōu)先級高于棧頂運算符優(yōu)先級递胧,則將A入棧opStack
2.如果A的優(yōu)先級低于或等于棧頂運算符的優(yōu)先級,那么將棧頂?shù)脑爻鰲4嫒雂List赡茸,重復此步驟直到棧頂?shù)倪\算符優(yōu)先級低于當前運算符(或者遇到括號),然后A入棧缎脾。
3.如果A是左括號“(”直接入棧,如果是右括號“)”占卧,則將opStack中的運算符彈出存入dList赊锚,直到彈出左括號治筒,左右括號均不存入dList,左括號永遠不會彈出舷蒲,直到遇到右括號耸袜。
4.不斷重復以上步驟直到表達式解析完成。

下面來看一下上面的具體例子:a+b-c*(d+e)

dList opStack 解釋
{} {}
{a} {} a 加入dList
{a} {+} + 入棧
{a,b} {+} b 加入dList
{a,b,+} {-} +號出棧牲平,-號入棧
{a,b,+,c} {-} c 加入dList
{a,b,+,c} {-,*} 因為* 的優(yōu)先級高于- 則將* 直接入棧
{a,b,+,c} {-,*,(} 左括號直接入棧
{a,b,+,c,d} {-,*,(} d 加入dList
{a,b,+,c,d} {-,*,(,+} + 直接入棧
{a,b,+,c,d,e} {-,*,(,+} e 直接加入dList
{a,b,+,c,d,e,+} {-,*} 將左括號之上的符號出棧加入dList
{a,b,+,c,d,e,+,*,-} {} 將棧中的剩余元素彈出

將dList 中的元素輸出堤框,則得到后綴表達式:ab+cde+*-

3.2 用后綴表達式來計算結(jié)果

首先建立一個結(jié)果棧rStack,然后將dList中的元素依次取出纵柿,進行入棧操作蜈抓,如果碰到操作符就從棧中取出兩個元素進行運算,結(jié)果入棧昂儒,依次重復沟使。

下面接著看上面的例子
dList {a,b,+,c,d,e,+,*,-}

rStack

{ } 
{a}   //a入棧 
{a,b} //b入棧 
{a+b} //遇到+號,取出兩個操作數(shù)進行運算渊跋,運算結(jié)果入棧 
{a+b,c} 
{a+b,c,d} 
{a+b,c,d,e} 
{a+b,c,d+e} 
{a+b,c*(d+e)} 
{a+b-c*(d+e)} 

計算結(jié)果:a+b-c*(d+e)

4腊嗡、鞏固練習:

寫出a*(b-c*d)+e-f/g*(h+i*j-k)的逆波蘭表達式。

答案:

abcd*-*e+fg/hij*+k-*-
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末拾酝,一起剝皮案震驚了整個濱河市燕少,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蒿囤,老刑警劉巖客们,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異材诽,居然都是意外死亡底挫,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進店門脸侥,熙熙樓的掌柜王于貴愁眉苦臉地迎上來凄敢,“玉大人,你說我怎么就攤上這事湿痢±苑欤” “怎么了?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵譬重,是天一觀的道長拒逮。 經(jīng)常有香客問我,道長臀规,這世上最難降的妖魔是什么滩援? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮塔嬉,結(jié)果婚禮上玩徊,老公的妹妹穿的比我還像新娘租悄。我一直安慰自己,他們只是感情好恩袱,可當我...
    茶點故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布泣棋。 她就那樣靜靜地躺著,像睡著了一般畔塔。 火紅的嫁衣襯著肌膚如雪潭辈。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天澈吨,我揣著相機與錄音把敢,去河邊找鬼。 笑死谅辣,一個胖子當著我的面吹牛修赞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播桑阶,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼柏副,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了联逻?” 一聲冷哼從身側(cè)響起搓扯,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤检痰,失蹤者是張志新(化名)和其女友劉穎包归,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體铅歼,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡公壤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了椎椰。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片厦幅。...
    茶點故事閱讀 38,646評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖慨飘,靈堂內(nèi)的尸體忽然破棺而出确憨,到底是詐尸還是另有隱情,我是刑警寧澤瓤的,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布休弃,位于F島的核電站,受9級特大地震影響圈膏,放射性物質(zhì)發(fā)生泄漏塔猾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一稽坤、第九天 我趴在偏房一處隱蔽的房頂上張望丈甸。 院中可真熱鬧糯俗,春花似錦、人聲如沸睦擂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽祈匙。三九已至忽刽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間夺欲,已是汗流浹背跪帝。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留些阅,地道東北人伞剑。 一個月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像市埋,于是被迫代替她去往敵國和親黎泣。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,514評論 2 348

推薦閱讀更多精彩內(nèi)容