forked from HarshCasper/NeoAlgo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck_valid_parenthesis_string.py
86 lines (73 loc) · 2.83 KB
/
check_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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#!/usr/bin/python
# -*- coding: utf-8 -*-
'''
PROBLEM STATEMENT
Given a string of '(' , ')' and lowercase english characters.
The task is to remove the minimum number of parentheses so
that the resulting parentheses string is valid.
A parentheses string is valid if and only if:
1.It is the empty string, contains only lowercase characters, or
2.It can be written as AB (A concatenated with B), where A and B are valid strings, or
3.It can be written as (A), where A is a valid string.
Implementation By: Nandini Bansal (GitHub: nandinib1999)
Method:
We can process a string which may possbily have unbalanced parentheses.
It makes use of a stack to store in the indices of the opening parenthesis
when encountered one and pops the index from the top of the stack when a
closing parenthesis is encountered. If a closing parentheses is encountered
while the stack is empty, its index is saved in an array "indx".
At the end of string traversal, we combine the "stack" and "indx" as
they contain the indices of unpaired opening and closing brackets.
An output string is generated after skipping the characters at indices
left in "stack" and "indx".
Argument: string (Input string with parenthesis)
Return: string (Output string with balanced parenthesis)
'''
def remove_parenthesis(string):
'''
Returns a string after removing minimum number of parentheses to make it balanced.
Parameters:
string (str): A string input
Returns:
op_str (str): A valid parentheses string
'''
stack = []
indx = []
for (i, s) in enumerate(string):
if s == '(':
# save the index of ( in stack
stack.append(i)
elif s == ')':
if len(stack) > 0:
# pop the index of ( on the top of stack if stack is not empty
_ = stack.pop()
else:
# if stack is empty, save the index of ) in indx array
indx.append(i)
else:
# no action taken for other character of the string
continue
# Generating the output string by skipping the unpaired parenthesis
# whose indices are saved in "stack" and "indx"
op_str = ''
# combine the list of indices and sort the indices
final_indx = indx + stack
final_indx.sort()
for (i, s) in enumerate(string):
# if index is in final_indx i.e. has unpaired parenthesis, skip it
if i in final_indx:
pass
else:
op_str = op_str + s
return op_str
if __name__ == '__main__':
inp_str = input().strip()
output_str = remove_parenthesis(inp_str)
print(output_str)
# Time Complexity: O(n)
# Testcases
# (1) Input: (()))() Output: (())()
# (2) Input: neoalgo Output: neoalgo
# (3) Input: ())(() Output: ()()
# (4) Input: )))((( Output: ''
# (5) Input: (())() Output: (())()