mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-10 18:48:13 +08:00
78 lines
3.5 KiB
HTML
78 lines
3.5 KiB
HTML
<p>给定一个表达式如 <code>expression = "e + 8 - a + 5"</code> 和一个求值映射,如 <code>{"e": 1}</code>(给定的形式为 <code>evalvars = ["e"]</code> 和 <code>evalints = [1]</code>),返回表示简化表达式的标记列表,例如 <code>["-1*a","14"]</code></p>
|
||
|
||
<ul>
|
||
<li>表达式交替使用块和符号,每个块和符号之间有一个空格。</li>
|
||
<li>块要么是括号中的表达式,要么是变量,要么是非负整数。</li>
|
||
<li>变量是一个由小写字母组成的字符串(不包括数字)。请注意,变量可以是多个字母,并注意变量从不具有像 <code>"2x"</code> 或 <code>"-x"</code> 这样的前导系数或一元运算符 。</li>
|
||
</ul>
|
||
|
||
<p>表达式按通常顺序进行求值:先是括号,然后求乘法,再计算加法和减法。</p>
|
||
|
||
<ul>
|
||
<li>例如,<code>expression = "1 + 2 * 3"</code> 的答案是 <code>["7"]</code>。</li>
|
||
</ul>
|
||
|
||
<p>输出格式如下:</p>
|
||
|
||
<ul>
|
||
<li>对于系数非零的每个自变量项,我们按字典排序的顺序将自变量写在一个项中。
|
||
<ul>
|
||
<li>例如,我们永远不会写像 <code>“b*a*c”</code> 这样的项,只写 <code>“a*b*c”</code>。</li>
|
||
</ul>
|
||
</li>
|
||
<li>项的次数等于被乘的自变量的数目,并计算重复项。我们先写出答案的最大次数项,用字典顺序打破关系,此时忽略词的前导系数。
|
||
<ul>
|
||
<li>例如,<code>"a*a*b*c"</code> 的次数为 4。</li>
|
||
</ul>
|
||
</li>
|
||
<li>项的前导系数直接放在左边,用星号将它与变量分隔开(如果存在的话)。前导系数 1 仍然要打印出来。</li>
|
||
<li>格式良好的一个示例答案是 <code>["-2*a*a*a", "3*a*a*b", "3*b*b", "4*a", "5*c", "-6"]</code> 。</li>
|
||
<li>系数为 <code>0</code> 的项(包括常数项)不包括在内。
|
||
<ul>
|
||
<li>例如,<code>“0”</code> 的表达式输出为 <code>[]</code> 。</li>
|
||
</ul>
|
||
</li>
|
||
</ul>
|
||
|
||
<p><strong>注意:</strong>你可以假设给定的表达式均有效。所有中间结果都在区间 <code>[-2<sup>31</sup>, 2<sup>31</sup> - 1]</code> 内。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例 1:</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入:</strong>expression = "e + 8 - a + 5", evalvars = ["e"], evalints = [1]
|
||
<strong>输出:</strong>["-1*a","14"]
|
||
</pre>
|
||
|
||
<p><strong>示例 2:</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入:</strong>expression = "e - 8 + temperature - pressure",
|
||
evalvars = ["e", "temperature"], evalints = [1, 12]
|
||
<strong>输出:</strong>["-1*pressure","5"]
|
||
</pre>
|
||
|
||
<p><strong>示例 3:</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入:</strong>expression = "(e + 8) * (e - 8)", evalvars = [], evalints = []
|
||
<strong>输出:</strong>["1*e*e","-64"]
|
||
</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= expression.length <= 250</code></li>
|
||
<li><code>expression</code> 由小写英文字母,数字 <code>'+'</code>, <code>'-'</code>, <code>'*'</code>, <code>'('</code>, <code>')'</code>, <code>' '</code> 组成</li>
|
||
<li><code>expression</code> 不包含任何前空格或后空格</li>
|
||
<li><code>expression</code> 中的所有符号都用一个空格隔开</li>
|
||
<li><code>0 <= evalvars.length <= 100</code></li>
|
||
<li><code>1 <= evalvars[i].length <= 20</code></li>
|
||
<li><code>evalvars[i]</code> 由小写英文字母组成</li>
|
||
<li><code>evalints.length == evalvars.length</code></li>
|
||
<li><code>-100 <= evalints[i] <= 100</code></li>
|
||
</ul>
|