[백준] 5597

당당·2023년 4월 21일
0

백준

목록 보기
23/179

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

📔문제

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

📝예제 입력 2

9
30
6
12
10
20
21
11
7
5
28
4
18
29
17
19
27
13
16
26
14
23
22
15
3
1
24
25

📺예제 출력 2

2
8

🔍출처

Olympiad > Japanese Olympiad in Informatics > Japanese Olympiad in Informatics Qualification Round > JOI 2007 예선 2번
-문제를 번역한 사람: egpaltair


🧮알고리즘 분류

  • 구현

📃소스 코드

import java.util.Scanner;

public class Code5597 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		int[] student=new int[30];
		int num=0;
		Scanner scanner=new Scanner(System.in);
		int first=0;
		int second=0;
		int[] no=new int[2];
		
		for(int i=0;i<28;i++) {
			num=scanner.nextInt();
			student[num-1]=1;
		}
		
		for(int i=0;i<30;i++) {
			if(student[i]==0) {
				if(no[0]==0) {
					no[0]=i+1;
				}
				else {
					no[1]=i+1;
				}
			}
		}
		
		if(no[0]>no[1]) {
			System.out.println(no[1]);
			System.out.println(no[0]);
		}
		else {
			System.out.println(no[0]);
			System.out.println(no[1]);
		}

	}

}

📰출력 결과


📂고찰

먼저 처음은 두명의 안낸 애를 어디다 어떻게 저장할까.

두번째는 student에 또 에러 떴는데 num은 1부터 시작해서 그런것..

profile
MySQL DBA 신입 지원

0개의 댓글