mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-09-11 18:31:41 +08:00
存量题库数据更新
This commit is contained in:
@@ -1,39 +1,46 @@
|
||||
<p>给你一个以字符串形式表述的 <a href="https://baike.baidu.com/item/%E5%B8%83%E5%B0%94%E8%A1%A8%E8%BE%BE%E5%BC%8F/1574380?fr=aladdin" target="_blank">布尔表达式</a>(boolean) <code>expression</code>,返回该式的运算结果。</p>
|
||||
|
||||
<p>有效的表达式需遵循以下约定:</p>
|
||||
<p><strong>布尔表达式</strong> 是计算结果不是 <code>true</code> 就是 <code>false</code> 的表达式。有效的表达式需遵循以下约定:</p>
|
||||
|
||||
<ul>
|
||||
<li><code>"t"</code>,运算结果为 <code>True</code></li>
|
||||
<li><code>"f"</code>,运算结果为 <code>False</code></li>
|
||||
<li><code>"!(expr)"</code>,运算过程为对内部表达式 <code>expr</code> 进行逻辑 <strong>非的运算</strong>(NOT)</li>
|
||||
<li><code>"&(expr1,expr2,...)"</code>,运算过程为对 2 个或以上内部表达式 <code>expr1, expr2, ...</code> 进行逻辑 <strong>与的运算</strong>(AND)</li>
|
||||
<li><code>"|(expr1,expr2,...)"</code>,运算过程为对 2 个或以上内部表达式 <code>expr1, expr2, ...</code> 进行逻辑 <strong>或的运算</strong>(OR)</li>
|
||||
<li><code>'t'</code>,运算结果为 <code>true</code></li>
|
||||
<li><code>'f'</code>,运算结果为 <code>false</code></li>
|
||||
<li><code>'!(subExpr)'</code>,运算过程为对内部表达式 <code>subExpr</code> 进行 <strong>逻辑非</strong>(NOT)运算</li>
|
||||
<li><code>'&(subExpr<sub>1</sub>, subExpr<sub>2</sub>, ..., subExpr<sub>n</sub>)'</code>,运算过程为对 2 个或以上内部表达式 <code>subExpr<sub>1</sub>, subExpr<sub>2</sub>, ..., subExpr<sub>n</sub></code> 进行 <strong>逻辑与</strong>(AND)运算</li>
|
||||
<li><code>'|(subExpr<sub>1</sub>, subExpr<sub>2</sub>, ..., subExpr<sub>n</sub>)'</code>,运算过程为对 2 个或以上内部表达式 <code>subExpr<sub>1</sub>, subExpr<sub>2</sub>, ..., subExpr<sub>n</sub></code> 进行 <strong>逻辑或</strong>(OR)运算</li>
|
||||
</ul>
|
||||
|
||||
<p>给你一个以字符串形式表述的 <a href="https://baike.baidu.com/item/%E5%B8%83%E5%B0%94%E8%A1%A8%E8%BE%BE%E5%BC%8F/1574380?fr=aladdin" target="_blank">布尔表达式</a> <code>expression</code>,返回该式的运算结果。</p>
|
||||
|
||||
<p>题目测试用例所给出的表达式均为有效的布尔表达式,遵循上述约定。</p>
|
||||
|
||||
<p> </p>
|
||||
|
||||
<p><strong>示例 1:</strong></p>
|
||||
<p><strong class="example">示例 1:</strong></p>
|
||||
|
||||
<pre><strong>输入:</strong>expression = "!(f)"
|
||||
<strong>输出:</strong>true
|
||||
</pre>
|
||||
|
||||
<p><strong>示例 2:</strong></p>
|
||||
|
||||
<pre><strong>输入:</strong>expression = "|(f,t)"
|
||||
<strong>输出:</strong>true
|
||||
</pre>
|
||||
|
||||
<p><strong>示例 3:</strong></p>
|
||||
|
||||
<pre><strong>输入:</strong>expression = "&(t,f)"
|
||||
<pre>
|
||||
<strong>输入:</strong>expression = "&(|(f))"
|
||||
<strong>输出:</strong>false
|
||||
<strong>解释:</strong>
|
||||
首先,计算 |(f) --> f ,表达式变为 "&(f)" 。
|
||||
接着,计算 &(f) --> f ,表达式变为 "f" 。
|
||||
最后,返回 false 。
|
||||
</pre>
|
||||
|
||||
<p><strong>示例 4:</strong></p>
|
||||
<p><strong class="example">示例 2:</strong></p>
|
||||
|
||||
<pre><strong>输入:</strong>expression = "|(&(t,f,t),!(t))"
|
||||
<strong>输出:</strong>false
|
||||
<pre>
|
||||
<strong>输入:</strong>expression = "|(f,f,f,t)"
|
||||
<strong>输出:</strong>true
|
||||
<strong>解释:</strong>计算 (false OR false OR false OR true) ,结果为 true 。
|
||||
</pre>
|
||||
|
||||
<p><strong class="example">示例 3:</strong></p>
|
||||
|
||||
<pre>
|
||||
<strong>输入:</strong>expression = "!(&(f,t))"
|
||||
<strong>输出:</strong>true
|
||||
<strong>解释:</strong>
|
||||
首先,计算 &(f,t) --> (false AND true) --> false --> f ,表达式变为 "!(f)" 。
|
||||
接着,计算 !(f) --> NOT false --> true ,返回 true 。
|
||||
</pre>
|
||||
|
||||
<p> </p>
|
||||
@@ -41,7 +48,6 @@
|
||||
<p><strong>提示:</strong></p>
|
||||
|
||||
<ul>
|
||||
<li><code>1 <= expression.length <= 20000</code></li>
|
||||
<li><code>expression[i]</code> 由 <code>{'(', ')', '&', '|', '!', 't', 'f', ','}</code> 中的字符组成。</li>
|
||||
<li><code>expression</code> 是以上述形式给出的有效表达式,表示一个布尔值。</li>
|
||||
<li><code>1 <= expression.length <= 2 * 10<sup>4</sup></code></li>
|
||||
<li><code>expression[i]</code> 为 <code>'('</code>、<code>')'</code>、<code>'&'</code>、<code>'|'</code>、<code>'!'</code>、<code>'t'</code>、<code>'f'</code> 和 <code>','</code> 之一</li>
|
||||
</ul>
|
||||
|
Reference in New Issue
Block a user