Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 |
Tags
- 백준 #백준2217 #백준로프 #python
- 카카오 #프로그래머스 #python #코딩테스트 #오픈채팅방
- 카카오 코테
- 프로그래머스 #python #코딩테스트 #코테공부 #알고리즘 #dict
- 동
- 프로그래머스 #c++ #코딩테스트
- 그리디알고리즘 #그리디 #백준 #우선순위큐 #최소힙 #최대힙 #알고리즘 #코딩테스트 #python
- 프로그래머스 #NULL 처리하기
- 백준 #백준알고리즘 #알고리즘 #코딩테스트 #코딩테스트준비 #코테준비 #백준2110 #python #문제풀이
- 프로그래머스 #네트워크 #c++ #코딩테스트 #코테 #코테준비 #dfs
- 백준 #이거다시풀기
- 프로그래머스 #python #2021카카오 #카카오코테 #카카오인턴쉽
- 프로그래머스 #sql #mysql #코딩테스트
Archives
- Today
- Total
say repository
[프로그래머스] 키패드 누르기 python 본문
728x90
https://programmers.co.kr/learn/courses/30/lessons/67256
코딩테스트 연습 - 키패드 누르기
[1, 3, 4, 5, 8, 2, 1, 4, 5, 9, 5] "right" "LRLLLRLLRRL" [7, 0, 8, 2, 8, 3, 1, 5, 7, 6, 2] "left" "LRLLRRLLLRR" [1, 2, 3, 4, 5, 6, 7, 8, 9, 0] "right" "LLRLLRLLRL"
programmers.co.kr
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 |