-
[백준] 14681번: 사분면 고르기코딩(Coding)/백준 문제풀이 2021. 1. 4. 16:31728x90
링크: www.acmicpc.net/problem/14681
14681번: 사분면 고르기
점 (x, y)의 사분면 번호(1, 2, 3, 4 중 하나)를 출력한다.
www.acmicpc.net
사분면 고르기
문제
흔한 수학 문제 중 하나는 주어진 점이 어느 사분면에 속하는지 알아내는 것이다. 사분면은 아래 그림처럼 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 중 하나)를 출력한다.
문제접근
해당 문제는 간단한 if-else if - else 문법을 이용해서 문제를 해결할 수 있다. 정말 간단하게도 문제에서 나타낸 그대로 코드로 표현하면 된다.
코드
""" 백준 알고리즘 14681번: 사분면 고르기 https://www.acmicpc.net/problem/14681 """ import sys def calc(x,y): if x > 0 and y > 0: return 1 elif x < 0 and y > 0: return 2 elif x < 0 and y < 0: return 3 else: return 4 def main(): x = int(sys.stdin.readline()) y = int(sys.stdin.readline()) print(calc(x,y)) if __name__ == "__main__": main()
해당 문제는 상황에 맞게 if문을 적절히 사용할 수 있는가를 묻는 문제인거 같다.
728x90'코딩(Coding) > 백준 문제풀이' 카테고리의 다른 글
[백준] 10871번: X보다 작은 수 (0) 2021.01.04 [백준] 2739번: 구구단 (0) 2021.01.04 [백준] 1436번: 영화감독 숌 (0) 2021.01.04 [백준] 1924번: 2007년 (0) 2020.12.31 [백준] 1920번: 수 찾기 (0) 2020.12.30