▶ 백준 알고리즘 14681
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)
12
5
9
-13
[예제 출력]
점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.
1
4
[제출 코드]
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String num1 = sc.next();
String num2 = sc.next();
if(num1.contains("-")) {
if(num2.contains("-")) {
System.out.println(3);
} else {
System.out.println(2);
}
} else {
if(num2.contains("-")) {
System.out.println(4);
} else {
System.out.println(1);
}
}
}
}
- contain 활용하여 "-" 유무를 판단하고, if/else로 구분
[추가 코드]
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int num1 = sc.nextInt();
int num2 = sc.nextInt();
if(num1 < 0) {
if(num2 < 0) {
System.out.println(3);
} else {
System.out.println(2);
}
} else {
if(num2 < 0) {
System.out.println(4);
} else {
System.out.println(1);
}
}
}
}
- 음수 판단 : 단순하게 '부등호'로 단순 구별이 가능함
728x90
'알고리즘' 카테고리의 다른 글
[JAVA] SWEA_2063(중간값 찾기) (0) | 2024.06.25 |
---|---|
[JAVA] 백준 알고리즘_2525(오븐 시계)* (2) | 2024.06.24 |
[JAVA] 백준 알고리즘_2753(윤달) (0) | 2024.06.22 |
[JAVA] 백준 알고리즘_2588(곱셈) (0) | 2024.06.22 |
[JAVA] 백준 알고리즘_111382(꼬마 정민) (0) | 2024.06.21 |