728x90
https://programmers.co.kr/learn/courses/30/lessons/67256
def solution(numbers, hand):
answer = ''
left_finger = 10 # 왼손 처음 * 위치
right_finger = 12 # 오른손 처음 #위치, 0은 11로 변경하기
for n in numbers:
if n in [1,4,7]: # 왼손 영역
answer += 'L'
left_finger = n
elif n in [3,6,9]: # 오른손 영역
answer += 'R'
right_finger = n
else: # 2 5 8 0 일 때
if n == 0: # 0은 11로
n = 11
# 왼손과 오른손과 눌러야 할 n 거리를 각각 구해준다.
left_dis = abs(n-left_finger)
right_dis = abs(n-right_finger)
left_dis = left_dis//3 + left_dis%3
right_dis = right_dis//3 + right_dis%3
# print("l",left_dis)
# print("r",right_dis)
if left_dis == right_dis: # 눌러야 할 거리가 왼손 오른손이 같으면 손잡이대로
if hand == "right": # 오른손 잡이는 오른손
answer += 'R'
right_finger = n
if hand == "left": # 왼손 잡이는 왼손
answer += 'L'
left_finger = n
elif left_dis < right_dis: # 왼손과 거리가 더 가까우면 왼손
answer += 'L'
left_finger = n
else: # 오른손이 더 가까우면 오른손
answer += 'R'
right_finger = n
return answer
풀이 1
2, 5, 8, 0 일 때 거리를 구하는 것에서 쫌 헷갈렸다.
처음에 abs(현재 손가락//3 -눌러야 할 손가락//3) + abs(현재 손가락%3 -눌러야 할 손가락%3) 이렇게 풀었더니 틀려서 규칙을 다시 찾았다.
abs(현재 손가락-눌러야 할 손가락)를 먼저 구해주고
이 값에서 3으로 나눈 값과 3으로 나눈 나머지를 더해줘서 비교해야 하는 것이었다.
def solution(numbers, hand):
answer = ''
left_finger = '*' # 왼손 처음 * 위치
right_finger = '#' # 오른손 처음 #위치
phone_num = {1 : (0,0), 2 : (0,1), 3 : (0,2),
4: (1, 0), 5: (1, 1), 6: (1, 2),
7: (2, 0), 8: (2, 1), 9: (2, 2),
'*': (3, 0), 0: (3, 1), '#': (3, 2)}
for n in numbers:
if n in [1,4,7]: # 왼손 영역
answer += 'L'
left_finger = n
elif n in [3,6,9]: # 오른손 영역
answer += 'R'
right_finger = n
else: # 2 5 8 0 일 때
# 왼손과 오른손과 눌러야 할 n 거리를 각각 구해준다.
cur = phone_num[n]
left_cur = phone_num[left_finger]
right_cur = phone_num[right_finger]
left_dis = abs(cur[0]-left_cur[0]) + abs(cur[1]-left_cur[1])
right_dis = abs(cur[0]-right_cur[0]) + abs(cur[1]-right_cur[1])
if left_dis == right_dis: # 눌러야 할 거리가 왼손 오른손이 같으면 손잡이대로
if hand == "right": # 오른손 잡이는 오른손
answer += 'R'
right_finger = n
if hand == "left": # 왼손 잡이는 왼손
answer += 'L'
left_finger = n
elif left_dis < right_dis: # 왼손과 거리가 더 가까우면 왼손
answer += 'L'
left_finger = n
else: # 오른손이 더 가까우면 오른손
answer += 'R'
right_finger = n
return answer
풀이 2
핸드폰의 버튼의 좌표를 정해서 딕셔너리로 관리해줬다.
더 직관적이고 깔끔한 것 같다.
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 완주하지 못한 선수 python (0) | 2022.03.23 |
---|---|
[프로그래머스] 크레인 인형뽑기 게임 python (0) | 2022.03.22 |
[프로그래머스] 신규 아이디 추천 python (0) | 2022.03.22 |
[프로그래머스] 숫자 문자열과 영단어 python (0) | 2022.03.22 |
[프로그래머스] 로또의 최고 순위와 최저 순위 python (0) | 2022.03.22 |