티스토리 뷰

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를 움직이게 한다.

반응형
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/02   »
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