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인 곳만 출력하면 된다