반응형
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
예제
입력 | 출력 |
|
2 8 |
|
2 8 |
풀이
-> 크기가 30인 배열을 만들어 둔 후, 28개의 숫자를 자기자신의 -1인 index를 가지는 배열의 값으로 둔다. 그러면 30개의 배열값 중에서 2개는 값이 0인 상태가 된다. 반복문을 통해서 배열의 값이 0이면 해당 index값에 +1을 해서 출력한다.
코드
import java.util.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
int[] array = new int [30];
for(int i=0;i<28;i++){
int number = sc.nextInt();
array[number-1] = number;
}
for(int i=0; i<30; i++){
if(array[i]==0){
System.out.println((i+1) + " ");
}
}
}
}
반응형
'Algorithm > 백준 단계별로 풀어보기' 카테고리의 다른 글
[백준 단계별로 풀어보기-심화] 그룹 단어 체커 (JAVA) (2) | 2024.03.19 |
---|---|
[백준 단계별로 풀어보기-문자열] 문자열 (JAVA) (0) | 2024.03.15 |
[백준 단계별로 풀어보기-문자열] 문자와 문자열 (JAVA) (0) | 2024.03.14 |
[백준 단계별로 풀어보기-반복문] 영수증 (JAVA) (0) | 2024.03.08 |
[백준 단계별로 풀어보기-조건문] 주사위 세개 (JAVA) (0) | 2024.03.08 |