LintCode 368 [Expression Evaluation]

原題

給一個(gè)用字符串表示的表達(dá)式數(shù)組,求出這個(gè)表達(dá)式的值台舱。

對(duì)于表達(dá)式 (2*6-(23+7)/(1+2)), 對(duì)應(yīng)的數(shù)組為:

[
  "2", "*", "6", "-", "(",
  "23", "+", "7", ")", "/",
  (", "1", "+", "2", ")"
]

其值為 2

解題思路

  • str與int相互轉(zhuǎn)化
num = int("15") // num = 15
s = str(num) // s = "15"
  • 表達(dá)式 -> 建立表達(dá)式樹(shù)
  • 表達(dá)式樹(shù) -> 求逆波蘭表達(dá)式
  • 逆波蘭表達(dá)式 -> 求值(使用stack)奈泪。遍歷逆波蘭表達(dá)式击狮,遇到+-*/除pop兩個(gè)數(shù)做相應(yīng)的運(yùn)算蕊苗,結(jié)果入棧筹陵。如果遇到數(shù)字刽锤,直接push入棧

完整代碼

class expressionTreeNode:
    def __init__(self, symbol):
        self.symbol = symbol
        self.left, self.right = None, None

class MyNode:
    def __init__(self, val, s):
        self.left = None
        self.right = None
        self.val = val
        self.exp_node = expressionTreeNode(s)

class Solution:
    # @param expression: a list of strings;
    # @return: an integer
    def get_val(self, a, base):
        if a == '+' or a == '-':
            return 1 + base
        if a == '*' or a == '/':
            return 2 + base
        return sys.maxint
        
    def create_tree(self, expression):
        stack = []
        base = 0
        for i in range(len(expression)):
            if expression[i] == '(':
                if base != sys.maxint:
                    base += 10
                continue
            elif expression[i] == ')':
                if base != sys.maxint:
                    base -= 10
                continue
            val = self.get_val(expression[i], base)
    
            node = MyNode(val, expression[i])
            while stack and val <= stack[-1].val:
                node.left = stack.pop()
            if stack:
                stack[-1].right = node
            stack.append(node)
        if not stack:
            return None
        return stack[0]
    
    def copy_tree(self, root):
        if not root:
            return None
        root.exp_node.left = self.copy_tree(root.left)
        root.exp_node.right = self.copy_tree(root.right)
        return root.exp_node
        
    def build(self, expression):
        root = self.create_tree(expression)
        return self.copy_tree(root)
        
    def dfs(self, root, list):
        if root == None:
            return
        if root.left:
            self.dfs(root.left, list)
        if root.right:
            self.dfs(root.right, list)
        list.append(root.symbol)
        
    def convertToRPN(self, expression):
        res = []
        root = self.build(expression)
        self.dfs(root, res)
        return res
        
    def evaluateExpression(self, expression):
        reversePolishNotation = self.convertToRPN(expression)
        stack = []
        operators = "+-*/"
        for str in reversePolishNotation:
            if str not in operators:
                stack.append(int(str))
            else:
                a = stack.pop()
                b = stack.pop()
                if str == "+":
                    stack.append(a + b)
                elif str == "-":
                    stack.append(b - a)
                elif str == "/":
                    stack.append(b / a)
                elif str == "*":
                    stack.append(a * b)
        if not stack:
            return 0
        return stack[-1]
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市朦佩,隨后出現(xiàn)的幾起案子并思,更是在濱河造成了極大的恐慌,老刑警劉巖语稠,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宋彼,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡仙畦,警方通過(guò)查閱死者的電腦和手機(jī)输涕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)卜高,“玉大人得滤,你說(shuō)我怎么就攤上這事倔撞。” “怎么了檐什?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)弱卡。 經(jīng)常有香客問(wèn)我乃正,道長(zhǎng),這世上最難降的妖魔是什么婶博? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任瓮具,我火速辦了婚禮,結(jié)果婚禮上凡蜻,老公的妹妹穿的比我還像新娘搭综。我一直安慰自己,他們只是感情好划栓,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布兑巾。 她就那樣靜靜地躺著,像睡著了一般忠荞。 火紅的嫁衣襯著肌膚如雪蒋歌。 梳的紋絲不亂的頭發(fā)上帅掘,一...
    開(kāi)封第一講書(shū)人閱讀 49,829評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音堂油,去河邊找鬼修档。 笑死,一個(gè)胖子當(dāng)著我的面吹牛府框,可吹牛的內(nèi)容都是我干的吱窝。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼迫靖,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼院峡!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起系宜,我...
    開(kāi)封第一講書(shū)人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤照激,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后盹牧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體俩垃,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年汰寓,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了口柳。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡有滑,死狀恐怖啄清,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情俺孙,我是刑警寧澤辣卒,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站睛榄,受9級(jí)特大地震影響荣茫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜场靴,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一啡莉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧旨剥,春花似錦咧欣、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至蚌父,卻和暖如春哮兰,著一層夾襖步出監(jiān)牢的瞬間毛萌,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工喝滞, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留阁将,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓右遭,卻偏偏與公主長(zhǎng)得像做盅,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子窘哈,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

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

  • 1 序 2016年6月25日夜言蛇,帝都,天下著大雨宵距,拖著行李箱和同學(xué)在校門(mén)口照了最后一張合照,搬離寢室打車(chē)去了提前租...
    RichardJieChen閱讀 5,082評(píng)論 0 12
  • 第5章 引用類(lèi)型(返回首頁(yè)) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類(lèi)型 使用基本類(lèi)型...
    大學(xué)一百閱讀 3,216評(píng)論 0 4
  • 第一章 緒論 什么是數(shù)據(jù)結(jié)構(gòu)吨拗? 數(shù)據(jù)結(jié)構(gòu)的定義:數(shù)據(jù)結(jié)構(gòu)是相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合满哪。 第二章...
    SeanCheney閱讀 5,758評(píng)論 0 19
  • 九 爸很生氣,他托關(guān)系劝篷,找人將晴月送進(jìn)了最好的重點(diǎn)班哨鸭,沒(méi)想到晴月居然成績(jī)直線下降不說(shuō),還被淘汰到了普通班娇妓。 那天放...
    萌芽mua閱讀 544評(píng)論 0 0
  • 你再次跟我提到這個(gè)問(wèn)題,辭職着绷!你說(shuō)你太累了蛔钙,不是身體上的累,是心累的不行了荠医。工作一個(gè)人干吁脱,不給增加人,出了問(wèn)題還得...
    zise紫色55555閱讀 321評(píng)論 0 0