[Java/알고리즘] 백준 5597 | 과제 안 내신 분...?

·2025년 8월 4일
0

문제

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

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

입력

입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.

출력

출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.


풀이

ArrayList를 이용한 풀이

  1. ArrayList를 이용해 입력
  2. 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();
	}
  }

🌟 배열과 인덱스를 이용한 풀이

  1. 길이가 30인 배열 생성
  2. 특정 숫자가 들어오면 해당 숫자 인덱스 값을 1로 설정
  3. 배열에서 값이 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);
        }
    }
}
profile
To Dare is To Do

0개의 댓글