给定一个表达式如 expression = "e + 8 - a + 5"
和一个求值映射,如 {"e": 1}
(给定的形式为 evalvars = ["e"]
和 evalints = [1]
),返回表示简化表达式的标记列表,例如 ["-1*a","14"]
"2x"
或 "-x"
这样的前导系数或一元运算符 。表达式按通常顺序进行求值:先是括号,然后求乘法,再计算加法和减法。
expression = "1 + 2 * 3"
的答案是 ["7"]
。输出格式如下:
“b*a*c”
这样的项,只写 “a*b*c”
。"a*a*b*c"
的次数为 4。["-2*a*a*a", "3*a*a*b", "3*b*b", "4*a", "5*c", "-6"]
。0
的项(包括常数项)不包括在内。
“0”
的表达式输出为 []
。注意:你可以假设给定的表达式均有效。所有中间结果都在区间 [-231, 231 - 1]
内。
示例 1:
输入:expression = "e + 8 - a + 5", evalvars = ["e"], evalints = [1] 输出:["-1*a","14"]
示例 2:
输入:expression = "e - 8 + temperature - pressure", evalvars = ["e", "temperature"], evalints = [1, 12] 输出:["-1*pressure","5"]
示例 3:
输入:expression = "(e + 8) * (e - 8)", evalvars = [], evalints = [] 输出:["1*e*e","-64"]
提示:
1 <= expression.length <= 250
expression
由小写英文字母,数字 '+'
, '-'
, '*'
, '('
, ')'
, ' '
组成expression
不包含任何前空格或后空格expression
中的所有符号都用一个空格隔开0 <= evalvars.length <= 100
1 <= evalvars[i].length <= 20
evalvars[i]
由小写英文字母组成evalints.length == evalvars.length
-100 <= evalints[i] <= 100