X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
import java.util.Scanner;
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int[] n = new int[28];
int[] num = new int[30];
Arrays.fill(num, 0);
for(int i=0; i<n.length; i++) {
n[i] = sc.nextInt();
for(int j=0; j<num.length; j++) {
if(n[i] == j+1)
num[j] = 1;
}
}
for(int i=0; i<num.length; i++) {
if(num[i] == 0) {
System.out.println(i+1);
}
}
}
}
과제를 안 낸 학생을 찾기 위해 우선 배열을 만들어서 낸 학생들의 출석번호를 받고, 30인 배열을 만들어 Arrays.fill()을 사용하여 배열 값을 0으로 초기화를 한 후, 낸 학생들의 번호에 1을 넣어 안 낸 학생들을 찾도록 하였다. 두개의 배열을 선언하였는데, 나중에 제출하고 나니까 배열을 하나만 받아도 됐었다는 것을 깨달았다. 게다가 이중for문도 필요 없었던... 오랜만에 풀었더니 생각을 많이 못하는거 같다. 앞으로 좀 더 생각을 해야할 거 같다.