-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path20-valid-parentheses.py
More file actions
38 lines (32 loc) · 935 Bytes
/
20-valid-parentheses.py
File metadata and controls
38 lines (32 loc) · 935 Bytes
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
"""
Given a string containing just the characters '(', ')', '{', '}', '[' and ']',
determine if the input string is valid.
An input string is valid if:
1. Open brackets must be closed by the same type of brackets.
2. Open brackets must be closed in the correct order.
Note that an empty string is also considered valid.
Example:
Input: "([)]"
Output: false
"""
class Solution(object):
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
stack = []
table = {'}': '{', ']': '[', ')': '('}
for char in s:
if char in table:
if not stack:
return False
if table[char] != stack.pop():
return False
else:
stack.append(char)
if stack:
return False
return True
if __name__ == "__main__":
print(Solution().isValid("([)]"))