-
Notifications
You must be signed in to change notification settings - Fork 2.4k
/
Copy path0678-valid-parenthesis-string.py
41 lines (35 loc) · 1.24 KB
/
0678-valid-parenthesis-string.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
# Dynamic Programming: O(n^2)
class Solution:
def checkValidString(self, s: str) -> bool:
dp = {(len(s), 0): True} # key=(i, leftCount) -> isValid
def dfs(i, left):
if i == len(s) or left < 0:
return left == 0
if (i, left) in dp:
return dp[(i, left)]
if s[i] == "(":
dp[(i, left)] = dfs(i + 1, left + 1)
elif s[i] == ")":
dp[(i, left)] = dfs(i + 1, left - 1)
else:
dp[(i, left)] = (
dfs(i + 1, left + 1) or dfs(i + 1, left - 1) or dfs(i + 1, left)
)
return dp[(i, left)]
return dfs(0, 0)
# Greedy: O(n)
class Solution:
def checkValidString(self, s: str) -> bool:
leftMin, leftMax = 0, 0
for c in s:
if c == "(":
leftMin, leftMax = leftMin + 1, leftMax + 1
elif c == ")":
leftMin, leftMax = leftMin - 1, leftMax - 1
else:
leftMin, leftMax = leftMin - 1, leftMax + 1
if leftMax < 0:
return False
if leftMin < 0: # required because -> s = ( * ) (
leftMin = 0
return leftMin == 0