根據 逆波蘭表示法,求表示式的值。
有效的算符包括 +、-、*、/ 。每個運算物件可以是整數,也可以是另乙個逆波蘭表示式。
說明:整數除法只保留整數部分。
給定逆波蘭表示式總是有效的。換句話說,表示式總會得出有效數值且不存在除數為 0 的情況。
示例 1:
輸入:tokens = [「2」,「1」,"+",「3」,"*"]
輸出:9
解釋:該算式轉化為常見的中綴算術表示式為:((2 + 1) * 3) = 9
示例 2:
輸入:tokens = [「4」,「13」,「5」,"/","+"]
輸出:6
解釋:該算式轉化為常見的中綴算術表示式為:(4 + (13 / 5)) = 6
示例 3:
輸入:tokens = [「10」,「6」,「9」,「3」,"+","-11","","/","",「17」,"+",「5」,"+"]
輸出:22
解釋:該算式轉化為常見的中綴算術表示式為:
((10 * (6 / ((9 + 3) * -11))) + 17) + 5
class
solution
:def
evalrpn
(self, tokens: list[
str])-
>
int:
ls =
demo =
["+"
,"-"
,"*"
,"/"
]while
len(tokens)!=1
:for i in
range
(len
(tokens)):
if tokens[i]
notin demo:
ls +=
[tokens[i]
]elif tokens[i]
in demo:
if tokens[i-2]
notin demo and tokens[i-1]
notin demo:
ls.pop(
) ls.pop(
) ls +=
[str
(int
(eval
(tokens[i-2]
+tokens[i]
+tokens[i-1]
)))]
else
: ls +=
[tokens[i]
] ls,tokens =
,ls return
(int
(tokens[0]
))
法二:
class
solution
:def
evalrpn
(self, tokens: list[
str])-
>
int:
iflen
(tokens)==1
:return
int(tokens[0]
) cnt = tokens.count(
"+")
+tokens.count(
"-")
+tokens.count(
"*")
+tokens.count(
"/")
ls =[0
]*(cnt)
flag =
0 demo =
["+"
,"-"
,"*"
,"/"
]for i in
range
(len
(tokens)):
if tokens[i]
in demo:
if tokens[i-2]
notin demo and tokens[i-1]
notin demo:
ls[flag]
=str
(int
(eval
(tokens[i-2]
+tokens[i]
+tokens[i-1]
))) flag +=
1continue
elif tokens[i-1]
notin demo:
ls[flag]
=str
(int
(eval
(ls[flag-1]
+tokens[i]
+tokens[i-1]
))) flag +=
1continue
else
:if tokens[i-4]
notin demo and tokens[i-3]
notin demo:
ls[flag]
=str
(int
(eval
(tokens[i-4]
+tokens[i]
+ls[flag-1]
))) flag +=
1continue
else
: ls[flag]
=str
(int
(eval
(ls[flag-2]
+tokens[i]
+ls[flag-1]
))) flag +=
1continue
return
(int
(ls[-1
]))
有bug.....絕大部分測試都能過,但就是有個陰間的過不去,邏輯上也沒找到啥,離譜....
150 逆波蘭表示式求值
根據逆波蘭表示法,求表示式的值。有效的運算子包括 每個運算物件可以是整數,也可以是另乙個逆波蘭表示式。說明 示例 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 解釋 ...
150 逆波蘭表示式求值
題目描述 根據逆波蘭表示法,求表示式的值。有效的運算子包括 每個運算物件可以是整數,也可以是另乙個逆波蘭表示式。說明 整數除法只保留整數部分。給定逆波蘭表示式總是有效的。換句話說,表示式總會得出有效數值且不存在除數為 0 的情況。示例 1 輸入 2 1 3 輸出 9 解釋 2 1 3 9 示例 2 ...
150 逆波蘭表示式求值
根據逆波蘭表示法,求表示式的值。有效的運算子包括 每個運算物件可以是整數,也可以是另乙個逆波蘭表示式。說明 整數除法只保留整數部分。給定逆波蘭表示式總是有效的。換句話說,表示式總會得出有效數值且不存在除數為 0 的情況。示例 1 輸入 2 1 3 輸出 9 解釋 2 1 3 9 示例 2 輸入 4 ...