티스토리 뷰
728x90
반응형
문제
https://programmers.co.kr/learn/courses/30/lessons/42860?language=python3#
코딩테스트 연습 - 조이스틱
조이스틱으로 알파벳 이름을 완성하세요. 맨 처음엔 A로만 이루어져 있습니다. ex) 완성해야 하는 이름이 세 글자면 AAA, 네 글자면 AAAA 조이스틱을 각 방향으로 움직이면 아래와 같습니다. ▲ - 다
programmers.co.kr
코드
def solution(name):
answer = 0
min_name = [min(ord(i) - ord('A'), ord('Z') - ord(i) + 1) for i in name]
print(min_name)
idx = 0
while True:
answer += min_name[idx]
min_name[idx] = 0
if sum(min_name) == 0:
break
left,right = 1,1
while min_name[idx - left] == 0:
left += 1
while min_name[idx + right] == 0:
right += 1
answer += left if left < right else right
idx += -left if left < right else right
return answer
조이스틱에서 위로 움직여서 알파벳을 바꾸는 것과 아래로 움직여서 바꾸는 것중에 최솟값을 찾아 리스트로 만든다.
ord로 문자열을 아스키코드로 만들어서 뺴주면 몇번 이동하는지 구할 수 있다.
그 다음에는 조이스틱을 왼쪽 또는 오른쪽으로 움직여야할 지를 판단해야하는데 A일 경우에는 바꾸지 않고 넘어가도 되므로 A가 right쪽에 많은지 left쪽에 많은지 판단해 더 적은 쪽으로 idx를 움직이게 한다.
반응형
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] Level1, 크레인 인형뽑기 게임 (Python) (0) | 2021.06.11 |
---|---|
[프로그래머스] Level2, 더 맵게 (Python) (0) | 2021.06.10 |
[프로그래머스] Level2, 점프와 순간 이동 (Python) (0) | 2021.06.10 |
[프로그래머스] Level2, 삼각 달팽이 (Python) (0) | 2021.06.10 |
[프로그래머스] Level2, 이진 변환 반복하기 (Python) (0) | 2021.06.09 |
댓글