-- 예전 기록/BOJ

[ BOJ ] 14681 : 사분면 고르기 ( BRONZE 5 ) / C, C++, Python, Java

rejo 2023. 8. 31. 11:39

문제

흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 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 의 좌표에 따른 사분면 정보를 조건문을 이용해 출력하면 되는 문제이다.

C

#include <stdio.h>

int main(void) {
    int x; scanf("%d", &x);
    int y; scanf("%d", &y);

    if (x > 0 && y > 0) printf("1");
    else if (x < 0 && y > 0) printf("2");
    else if (x < 0 && y < 0) printf("3");
    else printf("4");

    return 0;
}

C++

#include <iostream>
using namespace std;

int main(void) {
    int x; cin >> x;
    int y; cin >> y;

    if (x > 0 && y > 0) cout << 1;
    else if (x < 0 && y > 0) cout << 2;
    else if (x < 0 && y < 0) cout << 3;
    else cout << 4;

    return 0;
}

Python

import sys
input = sys.stdin.readline

x = int(input().rstrip())
y = int(input().rstrip())

if (x > 0 and y > 0): print(1)
elif (x < 0 and y > 0): print(2)
elif (x < 0 and y < 0): print(3)
else: print(4)

Java

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int x = sc.nextInt();
        int y = sc.nextInt();

        if (x > 0 && y > 0) System.out.println(1);
        else if (x < 0 && y > 0) System.out.println(2);
        else if (x < 0 && y < 0) System.out.println(3);
        else System.out.println(4);
    }
}