728x90
728x90
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
예제 입력 1
3
1
4
5
7
9
6
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
예제 출력 1
2
8
예제 입력 2
9
30
6
12
10
20
21
11
7
5
28
4
18
29
17
19
27
13
16
26
14
23
22
15
3
1
24
25
예제 출력 2
2
8
출처
- Olympiad > Japanese Olympiad in Informatics > Japanese Olympiad in Informatics Qualification Round > JOI 2007 예선 2번
알고리즘 분류
- 구현
문제 출처
https://www.acmicpc.net/problem/5597
문제 해결 방법
- 입력 받은 @n@ 값을 1차원 배열(@account@)의 인덱스로 사용한다. 그리고 해당 위치의 값을 @true@로 바꿔준다.
- for 문을 돌려서 값이 @false@인 배열의 인덱스를 출력시켜 준다.
- [단계별로 풀어보기] 문제집에 새로운 문제가 등록되어 문제를 풀어보았다.
코드
#include <iostream>
using namespace std;
int n;
bool account[31];
void Input() {
for (int i = 1; i <= 28; i++) {
cin >> n;
account[n] = true;
}
}
void Solution() {
for (int i = 1; i <= 30; i++) {
if (account[i] != true) {
cout << i << '\n';
}
}
}
void Solve() {
Input();
Solution();
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
Solve();
return 0;
}
채점 결과
참고
- [단계별로 풀어보기] > [1차원 배열]
- 브론즈V
728x90
728x90
'Problem Solving > BOJ' 카테고리의 다른 글
[BOJ-25305][C++] 커트라인 (0) | 2023.02.04 |
---|---|
[BOJ-2587][C++] 대표값2 (0) | 2023.02.04 |
[BOJ-2750][C++] 수 정렬하기 (0) | 2023.02.04 |
[BOJ-10757][C++] 큰 수 A+B (0) | 2023.02.04 |
[BOJ-10807][C++] 개수 세기 (0) | 2023.02.03 |
[BOJ-25682][C++] 체스판 다시 칠하기 2 (0) | 2023.01.26 |
[BOJ-2167][C++] 2차원 배열의 합 (0) | 2023.01.24 |
[BOJ-11660][C++] 구간 합 구하기 5 (2) | 2023.01.24 |