programmers - 키패드 누르기 |
https://school.programmers.co.kr/learn/courses/30/lessons/67256
문제 설명
스마트폰 전화 키패드의 각 칸에 다음과 같이 숫자들이 적혀 있습니다.
이 전화 키패드에서 왼손과 오른손의 엄지손가락만을 이용해서 숫자만을 입력하려고 합니다.
맨 처음 왼손 엄지손가락은 * 키패드에 오른손 엄지손가락은 # 키패드 위치에서 시작하며, 엄지손가락을 사용하는 규칙은 다음과 같습니다.
- 엄지손가락은 상하좌우 4가지 방향으로만 이동할 수 있으며 키패드 이동 한 칸은 거리로 1에 해당합니다.
- 왼쪽 열의 3개의 숫자 1, 4, 7을 입력할 때는 왼손 엄지손가락을 사용합니다.
- 오른쪽 열의 3개의 숫자 3, 6, 9를 입력할 때는 오른손 엄지손가락을 사용합니다.
- 가운데 열의 4개의 숫자 2, 5, 8, 0을 입력할 때는 두 엄지손가락의 현재 키패드의 위치에서 더 가까운 엄지손가락을 사용합니다.
4-1. 만약 두 엄지손가락의 거리가 같다면, 오른손잡이는 오른손 엄지손가락, 왼손잡이는 왼손 엄지손가락을 사용합니다.
순서대로 누를 번호가 담긴 배열 numbers, 왼손잡이인지 오른손잡이인 지를 나타내는 문자열 hand가 매개변수로 주어질 때, 각 번호를 누른 엄지손가락이 왼손인 지 오른손인 지를 나타내는 연속된 문자열 형태로 return 하도록 solution 함수를 완성해주세요.
문제 풀이
먼저 단계별로 어떻게 풀이해야할지 정리해봅시다.
1. 1,4,7 번은 무조건 왼손사용 3,6,9 번은 무조건 오른손 사용
2. 가운데 열 2,5,8,0 의 경우 왼손과 오른손의 각각 숫자까지의 거리를 계산해서 더 가까운 손을 사용해야함
3. 따라서 각 시행마다 왼손과 오른손의 위치를 변수로 지정해주어야하고, 숫자 까지의 거리를 어떻게 계산할 것인지만 생각하면 됨
문제에서 고민해야할 부분은 가운데 열 2,5,8,0을 누르는 경우를 어떻게 처리해야하는가 입니다.
핵심은 거리를 계산하는 것인데, 이때 휴대폰 키 패드를 2차원 배열로 생각하고 각 정점의 좌표를 통해 거리를 계산 할 수 있습니다. 각 x,y 좌표의 차이를 절댓값을 통해 더해주면 거리를 계산할 수 있습니다.
사실 이 부분만 해결하면 문제를 다 푼 것이나 다름 없습니다. 바로 코드로 가보시죵
풀이 코드
def search_idx(graph,number): for i in range(4): for j in range(3): if graph[i][j] == number: return i,j return 0,0 def solution(numbers, hand): answer = '' graph = [ [1,2,3], [4,5,6], [7,8,9], ['*',0,'#'], ] left_numbers = [1,4,7] right_numbers = [3,6,9] #왼손과 오른손의 시작 위치 지정 dl = '*' dr = '#' for number in numbers: if number in left_numbers: answer += "L" dl = number elif number in right_numbers: answer += "R" dr = number else: #dl과 dr과 number와의 거리비교를 위해 각 정점 인덱스 찾기 nx,ny = search_idx(graph,number) lx,ly = search_idx(graph,dl) rx,ry = search_idx(graph,dr) #dl과 dr에서 number까지 최단거리 계산 ld = abs(lx-nx) + abs(ly-ny) rd = abs(rx-nx) + abs(ry-ny) if ld < rd: answer += "L" dl = number elif rd < ld: answer += "R" dr = number else: if hand == "right": answer += "R" dr = number else: answer += "L" dl = number return answer |
'개인 공부 > 알고리즘 트레이닝' 카테고리의 다른 글
[python] programmers - 실패율 (1) | 2022.09.06 |
---|---|
[python] programmers - 크레인 인형뽑기 게임 (0) | 2022.09.05 |
[python] programmers - 숫자 문자열과 영단어 (0) | 2022.09.05 |
[python] programmers - 신규 아이디 추천 (0) | 2022.09.05 |
[python] programmers - 신고 결과 받기 (0) | 2022.09.02 |
댓글