给你一个以字符串形式表述的 布尔表达式(boolean) expression,返回该式的运算结果。
有效的表达式需遵循以下约定:
“t”,运算结果为 True
“f”,运算结果为 False
“!(expr)”,运算过程为对内部表达式 expr 进行逻辑 非的运算(NOT)
“&(expr1,expr2,…)”,运算过程为对 2 个或以上内部表达式 expr1, expr2, … 进行逻辑 与的运算(AND)
“|(expr1,expr2,…)”,运算过程为对 2 个或以上内部表达式 expr1, expr2, … 进行逻辑 或的运算(OR)
示例 1:
输入:expression = “!(f)”
输出:true
示例 2:
输入:expression = “|(f,t)”
输出:true
示例 3:
输入:expression = “&(t,f)”
输出:false
示例 4:
输入:expression = “|(&(t,f,t),!(t))”
输出:false
思路:
给定的字符串 expression是有效的布尔表达式,每个运算符后面都有一对括号,括号中有一个或多个表达式。其中,逻辑非运算符后面的括号中有一个表达式,逻辑与运算符和逻辑或运算符后面的括号中有两个或以上表达式。可以使用栈实现布尔表达式的解析。从左到右遍历布尔表达式,对于每种类型的字符,执行相应的操作:如果当前字符是逗号,则跳过该字符;如果当前字符是除了逗号和右括号以外的任意字符,则将该字符添加到栈内;如果当前字符是右括号,则一个表达式遍历结束,需要解析该表达式的值,并将结果添加到栈内。
代码:
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';
}
};
总结:今天的题目很难,思路也很复杂,比较难以想的全面,但是可以使用栈实现布尔表达式的解析,如果考虑到了栈这一块的话就比较容易想得到。总的来说,题目1虽然难,但是也不断的锻炼了自己的能力。