解析布尔表达式
示例
输入:expression = “!(f)”
输出:true
输入:expression = “|(f,t)”
输出:true
输入:expression = “&(t,f)”
输出:false
输入:expression = “|(&(t,f,t),!(t))”
输出:false
// C++
class Solution {
public:
bool parseBoolExpr(string expression) {
stack<char> stk;
int n = expression.size();
for (int i = 0; i < n; i++) {
char c = expression[i];
if (c == ',') {
continue;
} else if (c != ')') {
stk.push(c);
} else {
int t = 0, f = 0;
while (stk.top() != '(') {
char val = stk.top();
stk.pop();
if (val == 't') {
t++;
} else {
f++;
}
}
stk.pop();
char op = stk.top();
stk.pop();
switch (op) {
case '!':
stk.push(f == 1 ? 't' : 'f');
break;
case '&':
stk.push(f == 0 ? 't' : 'f');
break;
case '|':
stk.push(t > 0 ? 't' : 'f');
break;
default:
break;
}
}
}
return stk.top() == 't';
}
};