문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
문제풀이
학생이 총 30명이니 배열을 만들어 출석번호를 인덱스는 0부터 시작하기 때문에 출석번호-1로 인덱스 번호에 맞춰넣고 다시 그 배열을 돌아서 빠진 번호를 출력하도록 만들었다. 배열에 넣을 때 0번부터 맞춰넣기 때문에 정렬하거나 빠진 번호를 찾아서 작은거부터 출력하도록 조건을 걸 필요가 없다!
#include <iostream>
using namespace std;
int main (void){
int num[30];
int n;
for (int i = 0; i < 28; i++){
cin >> n;
num[n-1] = n;
}
for (int j = 1; j <= 30; j++){
if (j != num[j-1]){
cout << j <<endl;
}
}
}
'백준풀기' 카테고리의 다른 글
[c++] 백준 2525번 오븐시계 (1) | 2024.01.23 |
---|---|
[c++] 백준 1094번 막대기 (2진수) (2) | 2024.01.23 |
[c++] 백준 1009번 분산처리 (pow함수를 지양해야 하는 이유) (2) | 2024.01.22 |
[c++] 백준 1259번 팰린드롬(회문) (0) | 2024.01.17 |
[c++] 백준 1297번 (0) | 2024.01.16 |