BOJ - 14681

0l0l·2021년 4월 6일
0

Algorithm

목록 보기
4/11

if문

사분면 고르기

점이 어느 사분면에 있는지 알아내는 문제

◎ 문제

quadrant

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


▣ 문제 접근
먼저 x가 양수인지 음수인지 구분하고,
y가 양수일 때와 음수일 때를 나누어 해당 좌표가 속하는 사분면을 출력

▣ 코드

const readline = require('readline');

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

let input = [];
rl.on('line', function (line) {
  input.push(line);
}).on('close', function () {
  const x = parseInt(input[0]);
  const y = parseInt(input[1]);
  
  if ( x > 0 && x <= 1000 ) { // 양수(+)
    if ( y > 0 && y <= 1000) { // 양수(+)
      console.log(1);
    } else if ( y < 0 && y >= -1000 ) { // 음수(-)
      console.log(4);
    }
  } else if ( x < 0 && x >= -1000 ) { // 음수(-)
    if ( y > 0 && y <= 1000 ) { // 양수(+)
      console.log(2);
    } else if ( y < 0 && y >= -1000 ) { // 음수(-)
      console.log(3);
    }
  }
  
  process.exit();
});

▣ 설명
node.js의 fs 모듈을 사용하면 런타임 에러가 발생됨
readline 모듈을 사용해 실행함

readline 모듈 형식 익히기!

const readline = require('readline');

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

let input = []
rl.on('line', function (line) {
  input.push(line);
}).on('close', function () {
  const x = parseInt(input[0]);
  const y = parseInt(input[1]);
  
  // logic
  
  process.exit();
});
profile
천방지축 빙글빙글

0개의 댓글