-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path274.py
59 lines (49 loc) · 1.59 KB
/
274.py
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
"""
Problem:
Given a string consisting of parentheses, single digits, and positive and negative
signs, convert the string into a mathematical expression to obtain the answer.
Don't use eval or a similar built-in parser.
For example, given '-1 + (2 + 3)', you should return 4.
"""
def evaluate_expression(expression: str) -> int:
result = 0
add = True
sub_eval_string = ""
number_of_parentheses = 0
for char in expression:
if number_of_parentheses > 0:
# inside a set of parentheses
if char == "(":
number_of_parentheses += 1
elif char == ")":
number_of_parentheses -= 1
if number_of_parentheses == 0:
if add:
result += evaluate_expression(sub_eval_string)
else:
result -= evaluate_expression(sub_eval_string)
sub_eval_string = ""
else:
sub_eval_string += char
else:
if char == "-":
add = False
elif char == "+":
add = True
elif char == "(":
number_of_parentheses = 1
elif char.isdigit():
if add:
result += int(char)
else:
result -= int(char)
return result
if __name__ == "__main__":
print(evaluate_expression("-1 + (2 + 3)"))
print(evaluate_expression("-1 + (2 + 3) + (2 - 3)"))
print(evaluate_expression("-1 + (2 + 3) + ((2 - 3) + 1)"))
"""
SPECS:
TIME COMPLEXITY: O(n)
SPACE COMPLEXITY: O(n)
"""