알고리즘/문제
[그리디] 백준 18238 ZOAC 2
_Min
2021. 2. 10. 16:56
문제링크 www.acmicpc.net/problem/18238
index를 사용하는 문제
[답코드]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
import sys
input=sys.stdin.readline
n = input().strip() #ZOAC
alpha = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
result = 0
now = alpha.index('A')
for i in n:
target = alpha.index(i)
if abs(target-now) <= 13 :
result+=abs(target-now)
else:
result+=26-abs(target-now)
now=target
print(result)
|
cs |
[풀이법]
now에 현재 알파벳의 위치, target에 가고자 알파벳의 위치를 저장한다
abs(target-now)가 13이면 마주보고 있는 문자이다 (ex : A와 N의 거리는 13이다)
target과 now의 거리가 13이하면 오른쪽으로 돌려도 되지만 13 초과라면 반대쪽으로 돌려야 최솟값을 구할 수 있다
전체 알파벳의 갯수 26에서 target과 now의 거리를 빼면 반대쪽으로 돌렸을 때의 최솟값을 구할 수 있다.
브론즈라기에 간단하게 나오는 문제는 아니었던 거 같다
문자와 문자 사이의 거리를 구하기 위해 문자열.index() or list.index() 가 편리하다는 점,
문자열이 리스트처럼 인덱스값을 갖고 있는 점을 항상 숙지하면서 문제를 풀어야겠다.
728x90