[Rust로 백준 하루 하나] 2-4. 사분면 고르기

김진산·2024년 7월 26일

Rust로 백준 하루 하나

목록 보기
17/138
post-thumbnail

문제 (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 중 하나)를 출력한다.


풀이

코드

use std::io;

fn main() {
    let mut x = String::new();
    io::stdin().read_line(&mut x).unwrap();
    let x: i32 = x.trim().parse().unwrap();
    
    let mut y = String::new();
    io::stdin().read_line(&mut y).unwrap();
    let y: i32 = y.trim().parse().unwrap();
    
    let output: u8 = if x > 0 {
        if y > 0 { 1 }
        else { 4 }
    } else {
        if y > 0 { 2 }
        else { 3 }
    };
    println!("{output}");
}

해설

특이사항 없음


추가 학습

  • 사분면을 Division이라는 enum 타입으로 만들어서 풀어보자
profile
블록체인 개발자

0개의 댓글