https://www.acmicpc.net/problem/14681
문제
흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 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
풀이
이 문제는 매우 매우 간단하지만.. 정말 황당하게도 어이없는 곳에서 에러가 났습니다. 바로 런타임 에러! 구글링을 해 보니 다른 분들도 똑같은 현상을 겪으셨더라구요.. 사실 왜 런타임 에러가 나는지 아직 알 수 없지만 이 문제를 해결하기 위해서 두가지 방법이 일단은 가능하단 것을 알았습니다.
- fs (file system) 모듈 대신 readline 모듈을 사용하여 문제 해결
- readFileSync 안에 /dev/stdin 대신 0 을 넣어 사용
readline 을 사용하여 인풋을 받는 방법은 다음 알고리즘 문제 포스팅 때 올려보도록 하겠습니다.
코드는 이렇습니다.
const fs = require('fs');
const input = fs.readFileSync(0).toString().split('\n').map(input => Number(input));
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 {
console.log(4);
}
이건 진짜 쉽죠? 아마 이 포스트를 보시는 분들은 문제 해결 자체의 문제보다 아마 런타임 에러 때문일 거라 생각합니다.
다들 열공 하시고 모두 알고리즘 풀이 습관을 생활화 합시다!
'Studying > Algorithms' 카테고리의 다른 글
[알고리즘 떠먹여 주는 남자] 백준 8393 - 합 for Node.js (0) | 2022.04.04 |
---|---|
[알고리즘 떠먹여 주는 남자] 백준 1157 - 단어 공부 for Node.js (0) | 2022.04.04 |
[알고리즘 떠먹여 주는 남자] 백준 2525 - 오븐 시계 for Node.js (0) | 2022.04.03 |
[알고리즘 떠먹여 주는 남자] 백준 2884 - 알람 시계 for Node.js (0) | 2022.04.02 |
[알고리즘 떠먹여 주는 남자] 백준 2753: 윤년 for Node.js (0) | 2022.03.13 |