티스토리 뷰
728x90
https://www.acmicpc.net/problem/7567
- 문제 :
그릇을 바닥에 놓았을 때 그 높이는 10cm 이다. 그런데 두 개의 그릇을 같은 방향으로 포개면 그 높이는 5cm만 증가된다. 만일 그릇이 서로 반대방향으로 쌓이면 높이는 그릇만큼, 즉 10cm 늘어난다. 그릇을 괄호 기호로 나타내어 설명해보자. 편의상 그릇이 쌓여지는 방향은 왼쪽에서 오른쪽이라고 가정한다. 그림에서 ‘(’은 그릇이 바닥에 바로 놓인 상태를 나타내며, ‘)’은 그릇이 거꾸로 놓인 상태를 나타낸다.
만일 그릇이 포개진 모양이 ((((와 같다면 전체의 높이는 25cm가 된다. 왜냐하면 처음 바닥에 있는 그릇의 높이가 10cm이고 이후 같은 방향으로 3개의 그릇이 포개져 있으므로 늘어난 높이는 5+5+5=15 이기 때문이다. ()()와 같은 경우라면 그 높이는 10*4=40cm가 된다.
여러분은 입력에 주어진 모양대로 그릇을 쌓을 때 최종의 전체 그릇 높이를 계산해서 출력해야 한다. 즉 처음 입력으로 주어진 각 그릇의 방향은 바꿀 수 없다.
- 풀이 :
문자열 문제입니다.
알고리즘의 흐름은 다음과 같습니다.
1. 첫 번째 그릇은 무조건 10의 높이이므로 answer는 10부터 시작.
2. 2번째 접시부터 마지막 접시까지 탐색하며 이전 접시와 같은 방향이면 answer에 5를 더하고 아니라면 10을 더한다.
- 소스코드 :
s = input()
answer = 10
for i in range(1,len(s)):
if s[i] != s[i-1]: answer += 10
else: answer += 5
print(answer)
320x100
'Algorithm > String' 카테고리의 다른 글
(Python/파이썬) - 백준(BOJ) 15927번 : 회문은 회문아니야!! (1) | 2022.06.22 |
---|---|
(Python/파이썬) - 백준(BOJ) 21966번 : (중략) (0) | 2022.06.15 |
(Python/파이썬) - 백준(BOJ) 1316번 : 그룹 단어 체커 (0) | 2022.04.14 |
(Python) - BOJ(1032번) : 명령 프롬프트 (0) | 2022.03.02 |
(Python) - BOJ(2607번) : 비슷한 단어 (0) | 2022.02.18 |
댓글
© 2022 WonSeok, All rights reserved