X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명
이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명
이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호
를 구하는 프로그램을 작성하시오.
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)
가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
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
2
8
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
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부터 시작해서 그런것..