[boj node.js] 14681번 사분면 고르기 javascript

V·2022년 6월 27일
0
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 중 하나)를 출력한다.

예제 입력 1
12
5
예제 출력 1
1
예제 입력 2
9
-13
예제 출력 2
4

풀이

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

let input = [];
rl.on('line', function (line) {
  input.push(parseInt(line));
}).on('close', function () {
  const a = input[0];
  const b = input[1];

if (a>0 && b>0) {
    console.log(1);
} else if (a<0 && b>0){
    console.log(2);
} else if (a<0 && b<0){
    console.log(3);
} else if (a>0 && b<0){
    console.log(4);
}
    process.exit();
});
  • 이 풀이를 찾아보는 사람 중에는 fx모듈을 사용해서 입력을 받아와서 문제없이 답안을 작성 했음에도 문제가 풀리지 않는 경우가 있을 것이다. 결론적으로 이 문제는 잘못 만들어졌다. 일반적으로 입력을 간단하게 받아와서 풀기 위해 필자는 alfred의 snippet 기능을 활용해서 "bojfs" 를 입력하면 아래의 구문을 불러오게 저장을 해 두었다.
const fs = require('fs');
const input = fs.readFileSync('dev/stdin').toString().trim().split(' ');

하지만 올바르게 답안을 작성했음에도 불구하고 문제가 풀리지 않았었는데 다른 이들의 풀이를 참고하면서 fs 모듈로는 풀 수 없다는 사실을 알게 되었다. 아마 입력값을 받아오는 경로에 문제가 있는 것 같다.

profile
블로그 이전중 https://sungbeen.com

0개의 댓글