解题思路
看到表达式求解,自然想到栈。
从左至右遍历布尔表达式expression
,对于不同类型字符,进行不同操作:
- 逗号
,
,跳过该字符; - 不是逗号
,
和右括号)
,入栈; - 如果是右括号
)
,则一个表达式遍历结束,需要解析该表达式的值,并将结果入栈
- 出栈,直到栈顶元素是左括号
(
,然后将左括号(
和运算符出栈,记录弹出的t
和f
的个数;- 计算
t
和f
的表达式值:
2.1 运算符是!
,表达式的值为括号内的值取反,因此当f
的个数为1时表达式的值为t
,否则为f
;
2.2 运算符是&
,当括号内的所有值都是t
时结果是t
,否则结果是f
。
2.3 运算符是|
,当括号内至少有一个值是t
时结果是t
,否则是f
。
遍历结束后,栈内只有一个字符t
或f
,返回相应值即可。
核心代码如下:
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';
}
};
标签:运算符,top,stk,1106,括号,boolean,Parsing,expression,表达式
From: https://www.cnblogs.com/hql5/p/16860819.html