본문 바로가기
프로그래밍/백준 알고리즘

[백준 / node.js] 14681번: 사분면 고르기

by 정빈e 2021. 7. 21.
728x90

출처

 

14681번: 사분면 고르기

점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.

www.acmicpc.net

문제

흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 1부터 4까지 번호를 갖는다. "Quadrant n"은 "제n사분면"이라는 뜻이다.

백준 알고리즘 이미지이미지 출처: 백준

예를 들어, 좌표가 (12, 5)인 점 A는 x좌표와 y좌표가 모두 양수이므로 제1사분면에 속한다. 점 B는 x좌표가 음수이고 y좌표가 양수이므로 제2사분면에 속한다.

점의 좌표를 입력받아 그 점이 어느 사분면에 속하는지 알아내는 프로그램을 작성하시오. 단, x좌표와 y좌표는 모두 양수나 음수라고 가정한다.

입력

첫 줄에는 정수 x가 주어진다. (−1000 ≤ x ≤ 1000; x ≠ 0) 다음 줄에는 정수 y가 주어진다. (−1000 ≤ y ≤ 1000; y ≠ 0)

출력

점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.

예제 입력 1

12

5

예제 출력 1

1

예제 입력 2

9 -13

예제 출력 2

4

내 코드

const readline = require("readline");
const rl = readline.createInterface({
    input : process.stdin,
    output : process.stdout
});

const input = [];

rl.on("line", function(line){
    input.push(line);
}).on("close", function(){
    if(input[0] > 0 && input[1] > 0) console.log("1") // (양수, 양수)
    else if(input[0] < 0 && input[1] > 0) console.log("2") // (음수, 양수)
    else if(input[0] < 0 && input[1] < 0) console.log("3") // (음수, 음수)
    else if(input[0] > 0 && input[1] < 0) console.log("4") // (양수, 음수)
    process.exit();
})

결과

> 8
> 4
1
> -8
> 100
2
> -4
> -9
3
> 15
> -8
4

 사분면에 대해 알고 음수, 양수를 잘 체크하면 어렵지 않은 문제였다.

728x90

댓글