X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
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
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<stdio.h>
int main(){
int n[30] = { 0, };
int a;
for (int j = 0; j < 30; j++) {
n[j] = j+1;
}
for (int i = 0; i < 28; i++) {
scanf("%d", &a);
if (a == n[a - 1]) {
n[a-1] = 0;
}
}
for (int k = 0; k < 30; k++) {
if (n[k] != 0) {
printf("%d\n", n[k]);
}
}
}
머리가 안 돌아가서 며칠동안 붙잡았던 문제..
이 문제 역시나 종이에 끄적이며 풀었다......
먼저, n이라는 30개 배열에 1부터 30개의 숫자를 넣어준다.
제출한 번호 a를 입력받아 n배열에 있는 숫자이면 (a-1을 해주어 입력받은 숫자가 1이라면 n[0]==1) 0으로 바꿔 넣어준다.
*입력이 28줄이기 때문에 for문을 28번만 돌려 입력을 28번만 받는다.
이제 0이 되지 않은 배열 안의 숫자를 판별한 후 출력해주면 끝!
여기서 !=을 =!으로 쓴 건 비밀