[백준 27227] Дивизионы (C#, C++) - soo:bak
작성일 :
문제 링크
설명
간단한 구현 문제입니다.
문제의 설명에 따르면 대회의 참가자들은 점수에 따라서 참가할 수 있는 기본적인 경기 구역 이 정해져있습니다.
점수에 따른 구역은 다음과 같이 정해집니다.
0
<=점수
<=1600
:3
구역에 배정1601
<=점수
<=1900
:2
구역에 배정1901
<점수
:1
구역에 배정
문제의 목표는 참가자의 점수
에 따라서 참가할 수 있는 경기 구역
을 구하는 것입니다.
참가할 수 있는 경기 구역
에 대한 조건은 다음과 같습니다.
- 만약, 입장 가능한 구역중 자신이 배정된 구역이 있다면, 반드시 그 구역에만 입장해야 한다.
- 만약, 입장 가능한 구역중 자신이 배정된 구역이 없다면 다른 구역에 참가할 수 있다.
- 자신이 배정된 구역과 다른 구역에 참가하는 경우 중, 낮은 등급의 구역에는
번외
로만 참가할 수 있다.
위 조건들에 맞추어, 참가자가 참가할 수 있는 대회 구역을 구한 후 조건에 맞게 출력합니다.
번외
로 참가하는 경기 구역에 대해서는 경기 구역 번호 뒤에*
을 붙여야 합니다.
Code
[ C# ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
namespace Solution {
class Program {
static void Main(string[] args) {
var rating = int.Parse(Console.ReadLine()!);
var divisions = Console.ReadLine();
char defaultDivision = '1';
if (rating <= 1600) defaultDivision = '3';
else if (rating <= 1900) defaultDivision = '2';
if (divisions!.Contains(defaultDivision)) {
Console.WriteLine(defaultDivision);
return ;
}
foreach (char division in divisions) {
if (defaultDivision > division)
Console.WriteLine(division);
else if (defaultDivision < division)
Console.WriteLine($"{division}*");
}
}
}
}
[ C++ ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int rating; cin >> rating;
string divisions; cin >> divisions;
char defaultDivision = '1';
if (rating <= 1600) defaultDivision = '3';
else if (rating <= 1900) defaultDivision = '2';
if (divisions.find(defaultDivision) != string::npos) {
cout << defaultDivision << "\n";
return 0;
}
for (char c : divisions) {
char division = c;
if (defaultDivision > division)
cout << division << "\n";
else if (defaultDivision < division)
cout << division << "*\n";
}
return 0;
}