[프로그래머스] 키패드 누르기

Rae-eun Yang·2022년 7월 12일
0

프로그래머스

목록 보기
11/83

문제 설명


스마트폰 전화 키패드의 각 칸에 다음과 같이 숫자들이 적혀 있습니다.

이 전화 키패드에서 왼손과 오른손의 엄지손가락만을 이용해서 숫자만을 입력하려고 합니다.
맨 처음 왼손 엄지손가락은 * 키패드에 오른손 엄지손가락은 # 키패드 위치에서 시작하며, 엄지손가락을 사용하는 규칙은 다음과 같습니다.

  • 엄지손가락은 상하좌우 4가지 방향으로만 이동할 수 있으며 키패드 이동 한 칸은 거리로 1에 해당합니다.

  • 왼쪽 열의 3개의 숫자 1, 4, 7을 입력할 때는 왼손 엄지손가락을 사용합니다.

  • 오른쪽 열의 3개의 숫자 3, 6, 9를 입력할 때는 오른손 엄지손가락을 사용합니다.

  • 가운데 열의 4개의 숫자 2, 5, 8, 0을 입력할 때는 두 엄지손가락의 현재 키패드의 위치에서 더 가까운 엄지손가락을 사용합니다.
    4-1. 만약 두 엄지손가락의 거리가 같다면, 오른손잡이는 오른손 엄지손가락, 왼손잡이는 왼손 엄지손가락을 사용합니다.

순서대로 누를 번호가 담긴 배열 numbers, 왼손잡이인지 오른손잡이인 지를 나타내는 문자열 hand가 매개변수로 주어질 때, 각 번호를 누른 엄지손가락이 왼손인 지 오른손인 지를 나타내는 연속된 문자열 형태로 return 하도록 solution 함수를 완성해주세요.


제한 사항


  • numbers 배열의 크기는 1 이상 1,000 이하입니다.

  • numbers 배열 원소의 값은 0 이상 9 이하인 정수입니다.

  • hand는 "left" 또는 "right" 입니다.
    - "left"는 왼손잡이, "right"는 오른손잡이를 의미합니다.

  • 왼손 엄지손가락을 사용한 경우는 L, 오른손 엄지손가락을 사용한 경우는 R을 순서대로 이어붙여 문자열 형태로 return 해주세요.


입출력 예

numbershandresult
[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]이고, 오른손잡이입니다.

따라서 "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"이 됩니다.


풀이 코드 (Java)

import java.util.Stack;

class Solution {
	
		static int level(int curN){
          if(curN == 1 || curN == 2 || curN == 3) {
              return 1;
          }
          else if(curN == 4 || curN == 5 || curN == 6) {
              return 2;
          }
          else if(curN == 7 || curN == 8 || curN == 9) {
              return 3;
          }
          else return 4;
		}
	
	static String solution(int[] numbers, String hand) {
		String answer = "";
        Stack<Integer> Left = new Stack<>();
        Stack<Integer> Right = new Stack<>();

        Left.add(-1);
        Right.add(-2);
        
        for(int i = 0; i < numbers.length; i++){
        	
        	if(numbers[i] == 1 || numbers[i] == 4 || numbers[i] == 7) {
            	Left.add(numbers[i]);
            	answer += "L";
            }
            else if(numbers[i] == 3 || numbers[i] == 6 || numbers[i] == 9) {
            	Right.add(numbers[i]);
            	answer += "R";
            }
            else {	//2, 5, 8, 0일때
            	int level = level(numbers[i]);
            	int L = level(Left.peek());
            	int R = level(Right.peek());
            	int left = Math.abs(level-L);
            	int right = Math.abs(level-R);
            	if(!(Left.peek() == 2 || Left.peek() == 5 || Left.peek() == 8 || Left.peek() == 0)) {
                    left++;
            	}
            	if(!(Right.peek() == 2 || Right.peek() == 5 || Right.peek() == 8 || Right.peek() == 0)) {
            		right++;
            	}

            	
            	if(left < right) {
            		Left.add(numbers[i]);
            		answer += "L";
            	}
            	else if(left > right) {
            		Right.add(numbers[i]);
            		answer += "R";
            	}
            	else {
            		if(hand.equals("left")) {
            			Left.add(numbers[i]);
            			answer += "L";
            		} else {
            			Right.add(numbers[i]);
            			answer += "R";
            		}
            	}
            }
        }
        
        return answer;
    }
    
}


profile
개발자 지망생의 벨로그

0개의 댓글