문제
흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다.
사분면은 아래 그림처럼 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 중 하나)를 출력한다.
풀이
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int x = Integer.parseInt(br.readLine());
int y = Integer.parseInt(br.readLine());
if (x > 0){
if (y > 0) System.out.println(1);
else System.out.println(4);
} else {
if (y > 0) System.out.println(2);
else System.out.println(3);
}
}
}
* "Scanner" 대신 "BufferedReader" 를 사용해서 메모리 사용률과 실행시간을 줄여봤다.
'Algorithm(PS)' 카테고리의 다른 글
[백준/Python] 문제 15654 - N과 M (5) (0) | 2022.07.03 |
---|---|
[Algorithm] BFS & DFS (0) | 2022.06.04 |
[백준/Java] 문제 10867 - 중복 빼고 정렬하기 (0) | 2022.01.12 |
[백준/Java] 문제 10989 - 수 정렬하기 3 (0) | 2022.01.05 |
[백준/Java] 문제 2750 - 수 정렬하기 (0) | 2022.01.04 |