https://programmers.co.kr/learn/courses/30/lessons/67256?language=javascript
스마트폰 전화 키패드의 각 칸에 다음과 같이 숫자들이 적혀 있습니다.
이 전화 키패드에서 왼손과 오른손의 엄지손가락만을 이용해서 숫자만을 입력하려고 합니다.
맨 처음 왼손 엄지손가락은 * 키패드에 오른손 엄지손가락은 # 키패드 위치에서 시작하며, 엄지손가락을 사용하는 규칙은 다음과 같습니다.
순서대로 누를 번호가 담긴 배열 numbers, 왼손잡이인지 오른손잡이인 지를 나타내는 문자열 hand가 매개변수로 주어질 때, 각 번호를 누른 엄지손가락이 왼손인 지 오른손인 지를 나타내는 연속된 문자열 형태로 return 하도록 solution 함수를 완성해주세요.
"left"
또는 "right"
입니다."left"
는 왼손잡이, "right"
는 오른손잡이를 의미합니다.L
, 오른손 엄지손가락을 사용한 경우는 R
을 순서대로 이어붙여 문자열 형태로 return 해주세요.numbers | hand | result |
---|---|---|
[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" |
입출력 예 설명
입출력 예 #1
순서대로 눌러야 할 번호가 [1, 3, 4, 5, 8, 2, 1, 4, 5, 9, 5]이고, 오른손잡이입니다.
왼손 위치 | 오른손 위치 | 눌러야 할 숫자 | 사용한 손 | 설명 |
---|---|---|---|---|
* | # | 1 | L | 1은 왼손으로 누릅니다. |
1 | # | 3 | R | 3은 오른손으로 누릅니다. |
1 | 3 | 4 | L | 4는 왼손으로 누릅니다. |
4 | 3 | 5 | L | 왼손 거리는 1, 오른손 거리는 2이므로 왼손으로 5를 누릅니다. |
5 | 3 | 8 | L | 왼손 거리는 1, 오른손 거리는 3이므로 왼손으로 8을 누릅니다. |
8 | 3 | 2 | R | 왼손 거리는 2, 오른손 거리는 1이므로 오른손으로 2를 누릅니다. |
8 | 2 | 1 | L | 1은 왼손으로 누릅니다. |
1 | 2 | 4 | L | 4는 왼손으로 누릅니다. |
4 | 2 | 5 | R | 왼손 거리와 오른손 거리가 1로 같으므로, 오른손으로 5를 누릅니다. |
4 | 5 | 9 | R | 9는 오른손으로 누릅니다. |
4 | 9 | 5 | L | 왼손 거리는 1, 오른손 거리는 2이므로 왼손으로 5를 누릅니다. |
5 | 9 | - | - |
따라서 "LRLLLRLLRRL"
를 return 합니다.
입출력 예 #2
왼손잡이가 [7, 0, 8, 2, 8, 3, 1, 5, 7, 6, 2]를 순서대로 누르면 사용한 손은 "LRLLRRLLLRR"
이 됩니다.
입출력 예 #3
오른손잡이가 [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]를 순서대로 누르면 사용한 손은 "LLRLLRLLRL"
이 됩니다.
- 키패드를 좌표로 변환하고 Object로 생성한다.
- 왼손 시작 좌표와 오른손 시작 좌표를 각각 "*", "#"로 설정한다.
- 1,4,7,* 이면 L을 추가하고 왼손 좌표를 변경하고, 3,6,7,# 이면 R을 추가하고 오른손 좌표를 변경한다.
- 2,5,8,0 일 경우, 현재 왼손, 오른손 좌표와 눌러야 하는 번호의 좌표의 거리를 각각 구해서 작은 쪽으로 처리한다.
4-1. 둘이 같다면 주어진 왼손 또는 오른손으로 판별해서 처리한다.
function solution(numbers, hand) {
const keypad = {
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],
}
let answer = '';
let curLeft = keypad["*"];
let curRight = keypad["#"];
numbers.forEach(v=>{
if (v%3===1 || v === '*') {
answer+="L"
curLeft = keypad[v];
}
else if ((v%3===0 && v!==0) || v === '#') {
answer+="R"
curRight = keypad[v];
}
else {
let left = Distance(curLeft, keypad[v]);
let right = Distance(curRight, keypad[v]);
if (left < right) {
answer+="L";
curLeft = keypad[v];
}
else if (left > right) {
answer+="R";
curRight = keypad[v];
} else {
if (hand === "left") {
answer += "L"
curLeft = keypad[v];
} else {
answer+="R";
curRight = keypad[v];
}
}
}
});
return answer;
}
function Distance(arr1, arr2) {
let d = Math.abs(arr1[0] - arr2[0]) + Math.abs(arr1[1] - arr2[1]);
return d;
}
function solution(numbers, hand) {
hand = hand[0] === "r" ? "R" : "L"
let position = [1, 4, 4, 4, 3, 3, 3, 2, 2, 2]
let h = { L: [1, 1], R: [1, 1] }
return numbers.map(x => {
if (/[147]/.test(x)) {
h.L = [position[x], 1]
return "L"
}
if (/[369]/.test(x)) {
h.R = [position[x], 1]
return "R"
}
let distL = Math.abs(position[x] - h.L[0]) + h.L[1]
let distR = Math.abs(position[x] - h.R[0]) + h.R[1]
if (distL === distR) {
h[hand] = [position[x], 0]
return hand
}
if (distL < distR) {
h.L = [position[x], 0]
return "L"
}
h.R = [position[x], 0]
return "R"
}).join("")
}
// 출처: 프로그래머스
주어진 조건대로 구현하면 되는 문제였다.
거리를 구하는 부분이 약간 까다로웠다.