X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
- ArrayList를 이용해 입력
- 1-30 순회하며 없는 번호를 새로운 배열에 저장 후 출력
import java.util.Scanner;
public class Solution {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int T = sc.nextInt(); // test case 개수
for (int tc = 1; tc <= T; tc++) {
int[] arr = new int[10]; // 숫자 배열 선언
for (int i = 0; i < 10; i++) { // 숫자 배열 저장
arr[i] = sc.nextInt();
}
int max = -99999;
for (int num : arr) { // 배열 순회하며 최댓값 찾기
if (num > max) {
max = num;
}
}
System.out.println("#" + tc + " " + max);
}
sc.close();
}
}
- 길이가 30인 배열 생성
- 특정 숫자가 들어오면 해당 숫자 인덱스 값을 1로 설정
- 배열에서 값이 1이 아닌, 즉 0인 인덱스를 발견하면 출력
public class Main{
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int[] arr = new int[30];
for (int i = 0; i < 28; i++) {
arr[(Integer.parseInt(br.readLine())) - 1] = 1;
}
for (int i = 0; i < 30; i++) {
if (arr[i] == 1) continue;
System.out.println(i + 1);
}
}
}