본문 바로가기
Coding Test/Java Coding Test

[프로그래머스 / 자바] - PCCE 기출문제 5번 산책

by nam_ji 2024. 8. 26.

PCCE 기출문제 5번 산책 - LV.0

문제

  • 문자열 route가 매개변수로 주어집니다. 
  • 강아지를 산책시키려고 합니다.
  • 2차원 좌표평면에서 동/서/남/북 방향으로
  • 1m 단위로 이동하면서 강아지를 산책시킵니다.
  • 산책루트가 담긴 문자열 route가 주어질 때,
  • 도착점의 위치를 출력하도록 빈칸을 채워야 합니다.
    • route는 "N", "S", "E", "W"로 이루어져 있습니다.
      • "N"은 북쪽으로 1만큼 움직입니다.
      • "S"는 남쪽으로 1만큼 움직입니다.
        • 북쪽으로 -1만큼 움직인 것과 같습니다.
      • "E"는 동쪽으로 1만큼 움직입니다. 
      • "W"는 서쪽으로 1만큼 움직입니다.
        • 동쪽으로 -1만큼 움직인 것과 같습니다. 
    • 출발점으로부터 [동쪽으로 떨어진 거리, 북쪽으로 떨어진 거리]형태로
      강아지의 최종 위치를 구해서 return해야 합니다.
    • 출발점을 기준으로 서쪽, 남쪽에 있는 경우는 동쪽,
      북쪽으로 음수만큼 떨어진 것으로 표현합니다.
      • 출발점으로부터 동쪽으로 2,
        북쪽으로 3만큼 떨어졌다면 [2, 3]을 return 합니다.
      • 출발점으로부터 서쪽으로 1,
        남쪽으로 4만큼 떨어졌다면 [-1, -4]를 return 합니다.
  • 입출력 예
    • route result
      "NSSNEWWN" [-1, 1]
      "EESEEWNWSNWWNS" [0, 0]

 


테스트(인텔리제이)

  • 문제에 힌트를 얻어 풀었습니다.
  • N은 북쪽으로 1만큼 움직이고 S는 남쪽으로 1만큼이지만 북쪽으로 -1만큼 움직인 것과 같다는 문구를 보고
  • N이 호출되면 north를 1 증가하도록 한 것과 마찬가지로 S가 호출된다면 north를 1 감소하도록 하면 될 거라 생각하고
  • E가 호출되면 east를 1 증가하다록 한 것과 마찬가지로 W가 호출된다면 east를 1 감소하도록 하면 될 거라 생각하여
  • 풀 수 있었습니다.
package com.namji.codingtestpcce;

import java.util.Arrays;

public class PCCE_기출문제_5번_산책 {
  public static void main(String[] args) {
    /*
    문자열 route가 매개변수로 주어집니다.
    강아지를 산책시키려고 합니다.
    2차원 좌표평면에서 동/서/남/북 방향으로
    1m 단위로 이동하면서 강아지를 산책시킵니다.
    산책루트가 담긴 문자열 route가 주어질 때,
    도착점의 위치를 출력하도록 빈칸을 채워야 합니다.
    - route는 "N", "S", "E", "W"로 이루어져 있습니다.
      - "N"은 북쪽으로 1만큼 움직입니다.
      - "S"는 남쪽으로 1만큼 움직입니다.
        - 북쪽으로 -1만큼 움직인 것과 같습니다.
      - "E"는 동쪽으로 1만큼 움직입니다.
      - "W"는 서쪽으로 1만큼 움직입니다.
        - 동쪽으로 -1만큼 움직인 것과 같습니다.
    - 출발점으로부터 [동쪽으로 떨어진 거리, 북쪽으로 떨어진 거리]형태로
      강아지의 최종 위치를 구해서 return해야 합니다.
    - 출발점을 기준으로 서쪽, 남쪽에 있는 경우는 동쪽,
      북쪽으로 음수만큼 떨어진 것으로 표현합니다.
      - 출발점으로부터 동쪽으로 2,
        북쪽으로 3만큼 떨어졌다면 [2, 3]을 return 합니다.
      - 출발점으로부터 서쪽으로 1,
        남쪽으로 4만큼 떨어졌다면 [-1, -4]를 return 합니다.

    입출력 예
    route	            result
    "NSSNEWWN"	      [-1, 1]
    "EESEEWNWSNWWNS"	[0, 0]

    입출력 설명
    #1
    "NSSNEWWN" 순서대로 움직이면 서쪽으로 1,
    북쪽으로 1만큼 떨어진 곳에 도착하게 되므로 [-1, 1]을 return합니다.
    #2
    "EESEEWNWSNWWNS" 순서대로 움직이면 출발지와 같은 곳으로 돌아오므로 [0, 0]을 return합니다.
    cpp를 응시하는 경우 리스트는 배열과 동일한 의미이니 풀이에 참고해주세요.
      ex) 번호가 담긴 정수 리스트 numbers가 주어집니다.
          => 번호가 담긴 정수 배열 numbers가 주어집니다.
    java를 응시하는 경우 리스트는 배열, 함수는 메소드와 동일한 의미이니 풀이에 참고해주세요.
      ex) solution 함수가 올바르게 작동하도록 한 줄을 수정해 주세요.
          => solution 메소드가 올바르게 작동하도록 한 줄을 수정해 주세요.
     */
    String route = "EESEEWNWSNWWNS";
    int east = 0;
    int north = 0;
    int[] answer = new int [2];
    for(int i = 0; i < route.length(); i++){
      switch(route.charAt(i)){
        case 'N':
          north++;
          break;
        case 'S':
          north--;
          break;
        case 'E':
          east++;
          break;
        case 'W':
          east--;
          break;
      }
    }
    answer[0] = east;
    answer[1] = north;
    System.out.println(Arrays.toString(answer));
  }
}

S


프로그래머스 코드

class Solution {
    public int[] solution(String route) {
        int east = 0;
        int north = 0;
        int[] answer = new int [2];
        for(int i=0; i<route.length(); i++){
            switch(route.charAt(i)){
                case 'N':
                    north++;
                    break;
                case 'S':
                    north--;
                    break;
                case 'E':
                    east++;
                    break;
                case 'W':
                    east--;
                    break;
            }
        }
        answer[0] = east;
        answer[1] = north;
        return answer;
    }
}