leetcode 50 逆波蘭表示式求值

2021-09-12 13:31:46 字數 1479 閱讀 3173

根據逆波蘭表示法,求表示式的值。

有效的運算子包括 +, -, *, / 。每個運算物件可以是整數,也可以是另乙個逆波蘭表示式。

說明:整數除法只保留整數部分。

給定逆波蘭表示式總是有效的。換句話說,表示式總會得出有效數值且不存在除數為 0 的情況。

示例 1:

輸入:[「2」, 「1」, 「+」, 「3」, 「*」]

輸出:9

解釋: ((2 + 1) * 3) = 9

示例 2:

輸入:[「4」, 「13」, 「5」, 「/」, 「+」]

輸出:6

解釋: (4 + (13 / 5)) = 6

示例 3:

輸入:[「10」, 「6」, 「9」, 「3」, 「+」, 「-11」, 「", 「/」, "」, 「17」, 「+」, 「5」, 「+」]

輸出:22

解釋:((10 * (6 / ((9 + 3) * -11))) + 17) + 5

= ((10 * (6 / (12 * -11))) + 17) + 5

= ((10 * (6 / -132)) + 17) + 5

= ((10 * 0) + 17) + 5

= (0 + 17) + 5

= 17 + 5

= 22

思路:使用stack結構的先進後出的特點進行解決這個問題。stack儲存的是要計算的數字,遇到操作符號+,-,/,在 ** stack ** 彈出兩個數字進行對應的操作,然後再進棧。如果是運算元直接進棧,直到遍歷完了陣列,返回棧裡面的元素。

要特別注意的是進行除法的時候由於被除數先進棧,除數後進棧,所以去數的時候要小心,減法也是一樣的。

還有不能使用 == 去判斷操作符號是否相等,而是要用 equals 比較。

因為 == 在字串中比較的是兩個字串的位址空間,

而 equals 比較的是兩個字串的內容。

**:

class solution 

int op1, op2;

stackstack = new stack<>();

for(string token : tokens)

stack.push(op1);

}else

}return stack.pop();

}}

Leetcode 逆波蘭表示式求值

解題思路 c 通過乙個棧實現,整體用乙個while迴圈遍歷整個字串,當遇到不能把字元轉換成整型時進行判斷,同時將棧頂兩個元素出棧進行相關運算,運算結果放入棧中繼續進行遍歷。要點 不同資料型別之間的轉換,如果轉換成功則返回true,否則返回false。int.tryparse string s,out...

波蘭逆波蘭表示式

實現乙個基本的計算器來計算簡單的表示式字串。表示式字串只包含非負整數,算符 左括號 和右括號 整數除法需要 向下截斷 你可以假定給定的表示式總是有效的。所有的中間結果的範圍為 231,231 1 class solution s2.push s.substr l,r l l r 碰見符號 else ...

LeetCode 逆波蘭表示式求值 python3

根據 逆波蘭表示法,求表示式的值。有效的運算子包括 每個運算物件可以是整數,也可以是另乙個逆波蘭表示式。說明 整數除法只保留整數部分。給定逆波蘭表示式總是有效的。換句話說,表示式總會得出有效數值且不存在除數為 0 的情況。示例 1 輸入 2 1 3 輸出 9 解釋 該算式轉化為常見的中綴算術表示式為...