baekjoon

[백준] 5597 : 과제 안 내신 분..? - JAVA

juuuuuuun 2024. 2. 17. 17:10

문제

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

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

 

입력

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

예제 출력 1 

2
8

 

소스 코드 1

import java.util.Scanner;

//5597 과제 안 내신 분..?
public class 5597 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        int[] n = new int[30];

        int[] X = new int[30];
        //출석번호 입력
        for (int i = 0; i < 28; i++) {
            n[i] = scanner.nextInt();
            X[n[i] - 1] += 1;
        }

        for (int i = 0; i < 30; i++) {
            if (X[i] == 0) {
                System.out.println(i + 1);
            }
        }


    }
}

 

배열을 두개 선언하여 배열 n에는 출석한 학생 28명의 출석 번호를 입력받고, 배열 X에는 배열n에서 출석 번호를 입력 받을 때 마다 출석번호를 X의 인덱스로 넣어준 후 1을 더해줬다.

예를 들어 2번 출석번호를 입력 받으면 X의 2번째 인덱스인 X[2-1]에 1을 더하는 식으로 넣었다.

그리고 X에서 번호를 입력받지 못한 인덱스의 값은 0일 것 이므로 그 인덱스의 번호를 출력했다.

 

소스 코드 2

import java.util.Scanner;

//5597 과제 안 내신 분..?
public class 5597_2 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        int[] n = new int[30];

        //출석번호 입력
        for (int i = 0; i < 28; i++) {
            int num = scanner.nextInt();
            n[num - 1] = 1;
        }

        for (int i = 0; i < 30; i++) {
            if (n[i] == 0) {
                System.out.println(i + 1);
            }
        }


    }
}

 

위의 소스 코드1에서 배열을 두개 사용한게 복잡해 보여서 하나를 사용하는 방법도 생각해봤다

이번에는 num에 출석번호를 입력받고 배열 n에 인덱스에 그대로 넣어준 후 값을 1로 설정했다.

출력은 배열 n에서 값이 0인 곳만 출력하면 된다