문제

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

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


입력

입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.


출력

출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.


코드

#include <iostream>
#include <map>

using namespace std;

int main() {
    // >> Contain
    map<int, bool> dictionary; // : 키, 밸류 격납 변수 제작
    for(int index = 1; index <= 30; index++) {
        dictionary.insert(pair<int, bool>(index, false));
    }

    // >> Input
    for(int index = 0; index < 28; index ++) {
        // >> Process
        int input;
        cin >> input;
        dictionary.erase(input); // : 키를 통해 밸류를 삭제
    }

    // >> Output
    for(pair<int, bool> ele:dictionary){
		cout << ele.first << endl;
	}
}

참고

'C++ > Baekjoon' 카테고리의 다른 글

백준 11653: 소인수분해  (0) 2023.01.26
백준 1929: 소수 구하기  (0) 2023.01.24
백준 10807: 개수 세기  (0) 2022.12.17
백준 2839: 설탕 배달  (0) 2022.12.14
백준 2869: 달팽이는 올라가고 싶다  (0) 2022.12.06
블로그 이미지

RIsN

,