이 전화 키패드에서 왼손과 오른손의 엄지손가락만을 이용해서 숫자만을 입력하려고 합니다.
맨 처음 왼손 엄지손가락은 * 키패드에 오른손 엄지손가락은 # 키패드 위치에서 시작하며, 엄지손가락을 사용하는 규칙은 다음과 같습니다.
순서대로 누를 번호가 담긴 배열 numbers, 왼손잡이인지 오른손잡이인 지를 나타내는 문자열 hand가 매개변수로 주어질 때, 각 번호를 누른 엄지손가락이 왼손인 지 오른손인 지를 나타내는 연속된 문자열 형태로 return 하도록 solution 함수를 완성해주세요.
-> 자세한 내용 보러가기
class Solution {
public String solution(int[] numbers, String hand) {
StringBuilder sb = new StringBuilder();
int[][] keypad = {{1,2,3}
,{4,5,6}
,{7,8,9}
,{10,0,11}}; //10 = *, 11 = #
//최초 손가락의 위치
int leftX = 3; int leftY = 0; //왼손은 *
int rightX = 3; int rightY = 2; //오른손은 #
for(int num : numbers){
//손가락 위치를 변경해야하므로 각 숫자가 어디에 위치해 있는지 알아야함
int x = 0; int y = 0;
for(int i = 0; i < 4; i++){
for(int j = 0; j < 3; j++){
if(keypad[i][j] == num){
x = i;
y = j;
}
}
}
//왼쪽 : 1,4,7
if(num == 1 || num == 4 || num == 7){
sb.append("L");
//손가락 위치 변경
leftX = x;
leftY = y;
}else if(num == 3 || num == 6 || num ==9){
//오른쪽
sb.append("R");
rightX = x;
rightY = y;
}else{
//2,5,8,0 일 때는 가까운 위치의 엄지 손가락 이용
//왼손에서의 거리
int distanceX = Math.abs(leftX - x) + Math.abs(leftY - y);
//오른손에서의 거리
int distanceY = Math.abs(rightX - x) + Math.abs(rightY - y);
//왼손이 더 가깝다
if(distanceX < distanceY){
sb.append("L");
leftX = x;
leftY = y;
}else if(distanceX > distanceY){
sb.append("R");
rightX = x;
rightY = y;
}else{
//같다면? -> 왼손잡이 / 오른손잡이
if(hand.equals("left")){
sb.append("L");
leftX = x;
leftY = y;
}else if(hand.equals("right")){
sb.append("R");
rightX = x;
rightY = y;
}
}
}
}
return sb.toString();
}
}