난이도 : D4
문제번호 : 5432
문제 주소 및 출처입니다.
목차
1. 문제 설명
2. 문제 해석
3. 소스 코드
1. 문제 설명
여러 개의 쇠막대기를 레이저로 절단하려고 한다. 효율적인 작업을 위해서 쇠막대기를 아래에서 위로 겹쳐 놓고, 레이저를 위에서 수직으로 발사하여 쇠막대기들을 자른다. 쇠막대기와 레이저의 배치는 다음 조건을 만족한다. - 쇠막대기는 자신보다 긴 쇠막대기 위에만 놓일 수 있다. - 쇠막대기를 다른 쇠막대기 위에 놓는 경우 완전히 포함되도록 놓되, 끝점은 겹치지 않도록 놓는다. - 각 쇠막대기를 자르는 레이저는 적어도 하나 존재한다. - 레이저는 어떤 쇠막대기의 양 끝점과도 겹치지 않는다. 아래 그림은 위 조건을 만족하는 예를 보여준다. 수평으로 그려진 굵은 실선은 쇠막대기이고, 점은 레이저의 위치, 수직으로 그려진 점선 화살표는 레이저의 발사 방향이다. 이러한 레이저와 쇠막대기의 배치는 다음과 같이 괄호를 이용하여 왼쪽부터 순서대로 표현할 수 있다. 1. 레이저는 여는 괄호와 닫는 괄호의 인접한 쌍 “()” 으로 표현된다. 또한, 모든 “()”는 반드시 레이저를 표현한다. 2. 쇠막대기의 왼쪽 끝은 여는 괄호 ‘(’ 로, 오른쪽 끝은 닫힌 괄호 ‘)’ 로 표현된다. 위 예의 괄호 표현은 그림 위에 주어져 있다. 쇠막대기는 레이저에 의해 몇 개의 조각으로 잘려지는데, 위 예에서 가장 위에 있는 두 개의 쇠막대기는 각각 3개와 2개의 조각으로 잘려지고, 이와 같은 방식으로 주어진 쇠막대기들은 총 17개의 조각으로 잘려진다. 쇠막대기와 레이저의 배치를 나타내는 괄호 표현이 주어졌을 때, 잘려진 쇠막대기 조각의 총 개수를 구하는 프로그램을 작성하라. |
입력
첫 번째 줄에 테스트 케이스의 수 T가 주어진다. |
출력
각 테스트 케이스마다 #T를 출력하고 한 칸을 띄운 후, 잘려진 조각의 총 개수를 출력한다. |
예시
입력 | 출력 |
2 ()(((()())(())()))(()) (((()(()()))(())()))(()()) |
#1 17 #2 24 |
2. 문제풀이
예전에 프로그래머스에서 C++를 이용하여 풀었던 문제이다. 링크는 아래와 같다.
|
3. 소스코드
1
2
3
4
5
6
7
8
9
10
11
12
|
#D4 5432 쇠막대 자르기
for t in range(1, int(input())+1):
command = input()
stack = answer = 0
length = len(command)
for i in range(length):
if command[i] == '(': stack += 1
else:
stack -= 1
if command[i-1] == '(': answer += stack
else: answer += 1
print('#{} {}'.format(t, answer))
|
'코딩테스트 > SWExpertAcademy' 카테고리의 다른 글
정식이의 은행업무 Python(SW Expert Academy, SWEA) (0) | 2020.06.25 |
---|---|
추억의 2048게임 Python(SW Expert Academy, SWEA) (2) | 2020.06.24 |
최소 이동 거리 Python(SW Expert Academy, SWEA) (0) | 2020.06.22 |
최소 신장 트리 Python(SW Expert Academy, SWEA) (0) | 2020.06.21 |
연산 Python(SW Expert Academy, SWEA) (0) | 2020.06.20 |
댓글