力扣:1106. 解析布尔表达式

给你一个以字符串形式表述的 布尔表达式(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

提示:

1 <= expression.length <= 20000
expression[i] 由 {'(', ')', '&', '|', '!', 't', 'f', ','} 中的字符组成。
expression 是以上述形式给出的有效表达式,表示一个布尔值。

题目来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/parsing-a-boolean-expression
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
ps:记录用。。

public static boolean parseBoolExpr(String expression) {
		Stack stack = new Stack<>();
		int k = expression.length();
		for (int i = 0; i < k; i++) {
			if (expression.charAt(i) == ')') {
				String part = "";
				while (stack.peek() != '(') {
					part = stack.pop() + part;
				}
				stack.pop();
				switch (stack.pop()) {
				case '&':
					stack.push(part.indexOf('f') == -1 ? 't' : 'f'); // 与运算中只要有一个f就返回false
					break;
				case '|':
					stack.push(part.indexOf('t') != -1 ? 't' : 'f'); // 或运算中只要有一个t就返回true
					break;
				case '!':
					stack.push(part == "t" || "t".equals(part) ? 'f' : 't');
					break;
				}
			} else {
				stack.push(expression.charAt(i));
			}
		}
		return stack.pop() == 't' ? true : false;
	}

你可能感兴趣的:(java)