[백준 9610] 사분면 (C#, C++) - soo:bak
작성일 :
문제 링크
설명
여러 점이 주어질 때, 각 점이 어느 사분면에 있는지 또는 축 위에 있는지 세어 출력하는 문제입니다.
접근법
각 점의 좌표를 확인하여 분류합니다. x 또는 y가 0이면 축 위에 있습니다. 둘 다 0이 아니면 부호에 따라 사분면을 결정합니다. x와 y가 모두 양수면 1사분면, x가 음수이고 y가 양수면 2사분면, 둘 다 음수면 3사분면, x가 양수이고 y가 음수면 4사분면입니다. 각 경우의 개수를 세어 출력합니다.
Code
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
using System;
class Program {
static void Main() {
var n = int.Parse(Console.ReadLine()!);
var cnt = new int[5];
for (var i = 0; i < n; i++) {
var parts = Console.ReadLine()!.Split();
var x = int.Parse(parts[0]);
var y = int.Parse(parts[1]);
if (x == 0 || y == 0) cnt[0]++;
else if (x > 0 && y > 0) cnt[1]++;
else if (x < 0 && y > 0) cnt[2]++;
else if (x < 0 && y < 0) cnt[3]++;
else cnt[4]++;
}
for (var i = 1; i <= 4; i++)
Console.WriteLine($"Q{i}: {cnt[i]}");
Console.WriteLine($"AXIS: {cnt[0]}");
}
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n; cin >> n;
int cnt[5] = {0};
for (int i = 0; i < n; i++) {
int x, y; cin >> x >> y;
if (x == 0 || y == 0) cnt[0]++;
else if (x > 0 && y > 0) cnt[1]++;
else if (x < 0 && y > 0) cnt[2]++;
else if (x < 0 && y < 0) cnt[3]++;
else cnt[4]++;
}
for (int i = 1; i <= 4; i++)
cout << "Q" << i << ": " << cnt[i] << "\n";
cout << "AXIS: " << cnt[0] << "\n";
return 0;
}