반응형
문제
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고 부른다. 한 쌍의 괄호 기호로 된 “( )” 문자열은 기본 VPS 이라고 부른다. 만일 x 가 VPS 라면 이것을 하나의 괄호에 넣은 새로운 문자열 “(x)”도 VPS 가 된다. 그리고 두 VPS x 와 y를 접합(concatenation)시킨 새로운 문자열 xy도 VPS 가 된다. 예를 들어 “(())()”와 “((()))” 는 VPS 이지만 “(()(”, “(())()))” , 그리고 “(()” 는 모두 VPS 가 아닌 문자열이다.
여러분은 입력으로 주어진 괄호 문자열이 VPS 인지 아닌지를 판단해서 그 결과를 YES 와 NO 로 나타내어야 한다.
풀이
repeat = int(input())
while repeat > 0:
string = input()
stack = []
for i in string:
if len(stack) >= 1:
if stack[-1]=='(' and i ==')':
stack.pop()
continue
stack.append(i)
if (len(stack) == 0):
print('YES')
else:
print('NO')
repeat -=1
시간이 어떻게 하면 덜 걸릴까 ??? 🤔
반응형
'Python > 코딩테스트' 카테고리의 다른 글
[python] 프로그래머스 - 프린터 (0) | 2021.01.25 |
---|---|
[Python] 백준 1152번- 단어의 개수 (0) | 2021.01.25 |
[Python] 프로그래머스 - 두 정수 사이의 합 (0) | 2021.01.22 |
소수 구하기 (0) | 2021.01.10 |
[Python] 프로그래머스 - 문자열 내림차순으로 배치하기 (0) | 2020.12.19 |