Skip to content

Commit

Permalink
Added solution for issue 36 - valid parenthesis. Changed difficulty t…
Browse files Browse the repository at this point in the history
…o intermediate.
  • Loading branch information
akashsara committed Oct 6, 2018
1 parent 4c1a3e4 commit 2e961df
Showing 1 changed file with 22 additions and 0 deletions.
22 changes: 22 additions & 0 deletions intermediate/valid_parenthesis_akashsara.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
#!python3

def has_valid_parens(input_string):
"""
CHALLENGE:
Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the input string is valid.
An input string is valid if:
> Open brackets must be closed by the same type of brackets.
> Open brackets must be closed in the correct order.
> Note that an empty string is also considered valid.
DIFFICULTY: INTERMEDIATE [Due to use of stack]
"""
stack = []
bracket_map = {'[':']', '(':')', '{':'}'}
for bracket in input_string:
if bracket in bracket_map:
stack.append(bracket)
elif len(stack) == 0 or bracket_map[stack.pop()] != bracket:
return False
return len(stack) == 0

0 comments on commit 2e961df

Please sign in to comment.