[BOJ] #5597 - 과제 안 내신 분..?

👻 과제 안 내신 분..?

👉🏻 문제 보러가기 👈🏻


🌱 문제

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

교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.

  • 시간 제한 : 1초
  • 메모리 제한 : 128 MB

🌱 입력

입력은 총 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
    
  • 출력
    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
    8
    

👻 풀이

#include <iostream>
using namespace std;
int main()
{
    ios::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
    // 과제 안 내신 분..?
    int k = 28;
    int t[30] = {};
    while (k--) 
    {
        int n;
        cin >> n;
        t[n - 1] = n;
    }

    for (int i = 0; i < 30; i++)
    {
        if (t[i] == 0) cout << (i + 1) << '\n';
    }

    return 0;
}
  • 시간 : 0 ms
  • 메모리 : 2020 KB

👻 글을 마치며

반복문을 두 번 이상 돌지 않고서는 만들 수 없는지 생각해봤는데 내가 적은 코드가 최선인 것 같다. 다른 코드를 봐도 비슷한 것 같고 어렵지 않게 금방 풀 수 있었다.


소스코드 보러가기

Categories:

Updated:

Leave a comment