티스토리 뷰
T = int(input())
for tc in range(1, T+1):
arr = input()
N =len(arr)
stack1 = []
result = 1
left = 0
right = 0
#왼쪽괄호들을 다 스택에 저장하고 오른쪽 괄호를 만난다면 pop해서 비교
for i in range(N):
if arr[i] == '(' or arr[i] == '{':
stack1.append(arr[i])
left += 1
if arr[i] == ')':
right += 1
if len(stack1) > 0 and stack1.pop() != '(':
result = 0
break
elif arr[i] == '}':
right += 1
if len(stack1) > 0 and stack1.pop() != '{':
result = 0
break
if len(stack1) != 0: #스택에 비워지지 않았다면 왼쪽 괄호가 더 많은 것이므로 0
result = 0
if left != right:
result = 0
print("#{} {}".format(tc,result ))
'알고리즘 > SWEA' 카테고리의 다른 글
[SWEA] 3499. 퍼펙트셔플 (0) | 2021.02.23 |
---|---|
[SWEA] 4872.반복문자 지우기 (0) | 2021.02.23 |
[SWEA] 1218. 괄호 짝짓기 (0) | 2021.02.23 |
[SWEA] 2005. 파스칼의 삼각형 (0) | 2021.02.23 |
[SWEA] 1289. 원재의메모리복구 (0) | 2021.02.22 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- DOM
- 알고리즘
- Pyhton
- Python
- AWS
- SQL
- N과M
- vue.js
- SSAFY
- SWEA
- 안드로이드스튜디오
- 프로그래머스
- 파이썬
- 위클리챌린지2주차
- SSAFY퇴소
- commit되돌리기
- 비동기패턴
- splide
- 자바
- 세션 스토리지
- 백준
- 트리
- django
- vue
- Java
- 독학
- git
- 배포
- javascript
- 싸피
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함