[프로그래머스] Lv.0 점의 위치 구하기.java

김엄지·2024년 4월 24일

알고리즘

목록 보기
59/90

🐤 목표

앞으로 매일 꾸준히 코딩테스트를 진행하면서 단계를 높여가보자.

문제 설명

사분면은 한 평면을 x축과 y축을 기준으로 나눈 네 부분입니다. 사분면은 아래와 같이 1부터 4까지 번호를매깁니다.

x 좌표와 y 좌표가 모두 양수이면 제1사분면에 속합니다.
x 좌표가 음수, y 좌표가 양수이면 제2사분면에 속합니다.
x 좌표와 y 좌표가 모두 음수이면 제3사분면에 속합니다.
x 좌표가 양수, y 좌표가 음수이면 제4사분면에 속합니다.
x 좌표 (x, y)를 차례대로 담은 정수 배열 dot이 매개변수로 주어집니다. 좌표 dot이 사분면 중 어디에 속하는지 1, 2, 3, 4 중 하나를 return 하도록 solution 함수를 완성해주세요.

제한사항

dot의 길이 = 2
dot[0]은 x좌표를, dot[1]은 y좌표를 나타냅니다
-500 ≤ dot의 원소 ≤ 500
dot의 원소는 0이 아닙니다.

입출력의 예

문제 풀이

class Solution {
    public int solution(int[] dot) {
        int answer = 0;
        
        for(int i = 0; i < 2; i++) {
            if(dot[0] > 0 && dot[1] > 0) {
                answer = 1;
            } else if(dot[0] < 0 && dot[1] > 0) {
                answer = 2;
            } else if(dot[0] < 0 && dot[1] < 0) {
                answer = 3;
            } else {
                answer = 4;
            }
        }
        return answer;
    }
}

조건문을 사용해서 배열 dot의 0번째 값이 0보다 큰지 작은지, 1번째 값이 0보다 큰지 작은지 확인한다.

제 1사분면 (양수, 양수) -> 제 1사분면인 1을 반환한다.
제 2사분면 (음수, 양수) -> 제 2사분면인 2을 반환한다.
제 3사분면 (음수, 음수) -> 제 3사분면인 3을 반환한다.
제 4사분면 (양수, 음수) -> 제 4사분면인 4을 반환한다.

문제 풀이 2

class Solution {
    public int solution(int[] dot) {
        int answer = 0;
        
        if(dot[0] > 0) 
            if(dot[1] > 0) answer = 1;
            else answer = 4;
        else 
            if(dot[1] > 0) answer = 2;
            else answer = 3;

        return answer;
    }
}

다른 사람의 풀이를 보면서 처음에 조건문 2개만 나가는 풀이방법이 있었다.

profile
나만의 무언가를 가진 프로그래머가 되자

0개의 댓글