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.
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.
Input: expression = "|(f,f,f,t)" Output: true Explanation: The evaluation of (false OR false OR false OR true) is true.
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.
1 <= expression.length <= 2 * 104
- expression[i] is one following characters:
'('
,')'
,'&'
,'|'
,'!'
,'t'
,'f'
, and','
.
impl Solution {
pub fn parse_bool_expr(expression: String) -> bool {
let mut ops = vec![];
let mut bools = vec![];
for ch in expression.chars() {
match ch {
'!' | '&' | '|' => ops.push(ch),
't' | 'f' => bools.push(Some(ch == 't')),
')' => match ops.pop() {
Some('!') => {
let tmp = !bools.pop().unwrap().unwrap();
bools.pop();
bools.push(Some(tmp));
}
Some('&') => {
let mut tmp = true;
while let Some(Some(b)) = bools.pop() {
tmp &= b;
}
bools.push(Some(tmp));
}
Some('|') => {
let mut tmp = false;
while let Some(Some(b)) = bools.pop() {
tmp |= b;
}
bools.push(Some(tmp));
}
_ => {
let tmp = bools.pop().unwrap();
bools.pop();
bools.push(tmp);
}
},
'(' => bools.push(None),
_ => (),
}
}
bools[0].unwrap()
}
}