-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1106.cpp
65 lines (61 loc) · 1.48 KB
/
1106.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
#include "leetcode.hpp"
class Solution {
public:
bool parseBoolExpr(string expression) {
auto s = stack<char>();
for (auto c : expression) {
if (c == ')') {
vector<bool> operands;
while (s.top() == 't' || s.top() == 'f') {
operands.push_back(s.top() == 't' ? true : false);
s.pop();
}
switch (s.top()) {
case '!':
s.pop();
s.push(!operands.back() ? 't' : 'f');
break;
case '&': {
s.pop();
bool ret = true;
for (auto b : operands) {
if (!b) {
ret = false;
break;
}
}
s.push(ret ? 't' : 'f');
} break;
case '|': {
s.pop();
bool ret = false;
for (auto b : operands) {
if (b) {
ret = true;
break;
}
}
s.push(ret ? 't' : 'f');
} break;
default:
break;
}
} else if (c == '(' || c == ',') {
continue;
} else {
s.push(c);
}
}
return s.top() == 't' ? true : false;
}
};
int main(int argc, char const *argv[]) {
string t1 = "&(|(f))", t2 = "|(f,f,f,t)", t3 = "!(&(f,t))",
t4 = "|(f,&(t,t))";
Solution s;
auto ret = s.parseBoolExpr(t1);
ret = s.parseBoolExpr(t2);
ret = s.parseBoolExpr(t3);
ret = s.parseBoolExpr(t4);
return 0;
}