백준

[백준_5597번] 과제 안 내신 분..?

빙수빈수 2021. 8. 19. 19:19

https://www.acmicpc.net/problem/5597

 

5597번: 과제 안 내신 분..?

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

www.acmicpc.net

[문제]

X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다. 교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.

 

[입력 조건]

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

 

[코드]

import java.util.*;

public class BaekJoon_5597 {
	static boolean[] task=new boolean[31];
	static StringBuilder sb=new StringBuilder();
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc=new Scanner(System.in);
		
		for(int i=0;i<28;i++) {
			int num=sc.nextInt();
			
			// 과제를 제출한 번호는 true 처리
			task[num]=true;
		}
		
		for(int i=1;i<=30;i++) {
			// 과제를 안낸 사람의 번호 저장
			if(task[i]==false) {
				sb.append(i+" ");
				sb.append('\n');
			}
		}
		
		System.out.println(sb);
	}

}

 

[고찰]

 이번 문제는 30개의 번호 중 호명이 안된 2개를 찾는 아주 간단한 문제였다. boolean 배열을 사용하여 호명된 번호는 true 처리를 해준 후 30개의 값들 중 false인 값 2개를 찾아 해당 번호를 출력하는 방식으로 해결할 수 있다.