Rylah's Study & Daily Life

[BOJ/C++] 5597. 과제 안 내신 분..? 본문

BOJ

[BOJ/C++] 5597. 과제 안 내신 분..?

Rylah 2022. 5. 17. 12:42

https://www.acmicpc.net/problem/5597

 

5597번: 과제 안 내신 분..?

X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다. 교수님이 내준 특별과제를 28명이 제출했는데,

www.acmicpc.net

과제 안 내신 분..? 다국어

한국어   
시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 128 MB 10281 6701 6059 66.393%

문제

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

 

간단한 구현 문제

 

Counting Sort 사용했다.

 

break는 안써도 시간은 충분하겠지만 그냥 끊었다.

 

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
31
32
33
34
35
#include <bits/stdc++.h>
using namespace std;
 
int main(void)
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    
    vector<int> student(310);
    student[0= 1;
 
    for (int i = 0; i < 28; i++)
    {
        int sendReportStdNum;
        cin >> sendReportStdNum;
 
        student[sendReportStdNum]++;
    }
    int cnt = 0;
 
    for (int i = 0; i < static_cast<int>(student.size()); i++)
    {
        if (cnt == 2)
            break;
 
        if (student[i] != 0)
            continue;
 
        cout << i << "\n";
        cnt++;
 
    }
 
    return 0;
}
cs

 

'BOJ' 카테고리의 다른 글

[BOJ/C++] 2920. 음계  (0) 2022.05.17
[BOJ/C++] 6996. 애너그램  (0) 2022.05.17
[BOJ/C++] 2660. 회장 뽑기  (0) 2022.05.03
[BOJ/C++] 10162. 전자레인지  (0) 2022.04.26
[BOJ/C++] 9625. BABBA  (0) 2022.04.12