1106. Parsing A Boolean Expression
Description
A boolean expression is an expression that evaluates to either true
or false
. It can be in one of the following shapes:
't'
that evaluates totrue
.'f'
that evaluates tofalse
.'!(subExpr)'
that evaluates to the logical NOT of the inner expressionsubExpr
.'&(subExpr1, subExpr2, ..., subExprn)'
that evaluates to the logical AND of the inner expressionssubExpr1, subExpr2, ..., subExprn
wheren >= 1
.'|(subExpr1, subExpr2, ..., subExprn)'
that evaluates to the logical OR of the inner expressionssubExpr1, subExpr2, ..., subExprn
wheren >= 1
.
Given a string expression
that represents a boolean expression, return the evaluation of that expression.
It is guaranteed that the given expression is valid and follows the given rules.
Example 1:
Input: expression = "&(|(f))" Output: false Explanation: First, evaluate |(f) --> f. The expression is now "&(f)". Then, evaluate &(f) --> f. The expression is now "f". Finally, return false.
Example 2:
Input: expression = "|(f,f,f,t)" Output: true Explanation: The evaluation of (false OR false OR false OR true) is true.
Example 3:
Input: expression = "!(&(f,t))" Output: true Explanation: First, evaluate &(f,t) --> (false AND true) --> false --> f. The expression is now "!(f)". Then, evaluate !(f) --> NOT false --> true. We return true.
Constraints:
1 <= expression.length <= 2 * 104
- expression[i] is one following characters:
'('
,')'
,'&'
,'|'
,'!'
,'t'
,'f'
, and','
.
Solutions
Solution 1: Stack
For this type of expression parsing problem, we can use a stack to assist.
We traverse the expression expression
from left to right. For each character $c$ we encounter:
- If $c$ is one of
"tf!&|"
, we push it directly onto the stack; - If $c$ is a right parenthesis
')'
, we pop elements from the stack until we encounter an operator'!'
,'&'
, or'|'
. During this process, we use variables $t$ and $f$ to record the number of't'
and'f'
characters popped from the stack. Finally, based on the number of characters popped and the operator, we calculate a new character't'
or'f'
and push it onto the stack.
After traversing the expression expression
, there is only one character left in the stack. If it is 't'
, return true
, otherwise return false
.
The time complexity is $O(n)$, and the space complexity is $O(n)$. Here, $n$ is the length of the expression expression
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
|