TIL 54 | 자바스크립트로 알고리즘 (백준 14681 JS) 사분면 고르기

Gom·2021년 4월 13일
0

Algorithm

목록 보기
26/48
post-thumbnail

자바스크립트로 알고리즘 문제풀이


문제

흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 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 중 하나)를 출력한다.

접근

여러 줄을 입력받는 방식 활용
조건부분을 가장 효율적으로 표현할 수 있는 방법은 무엇이 있을까?


정답코드

const readline = require('readline');

const rl = readline.createInterface({
    input:process.stdin,
    output:process.stdout
});
let input = [];
rl.on('line', function (line) {
    if(line===""){
        rl.close();
    }
    input.push(line)
})
  .on('close', function () {
    const x = input[0];
    const y = input[1];
    if(x>0){
        if(y>0){
            console.log(1);
        }else console.log(4);
    }else{
        if(y>0){
            console.log(2);
        }else{
            console.log(3);
        }
    }
  process.exit();
});
profile
안 되는 이유보다 가능한 방법을 찾을래요

0개의 댓글