반응형
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
풀이
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
public class Main{
public static void main(String []args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
ArrayList<Integer> list = new ArrayList<>();
for(int i = 1 ; i<= 30; i++) {
list.add(i);
}
int totalNumber = 28;
while(totalNumber-- > 0) {
int studentNum = Integer.parseInt(br.readLine());
list.remove(list.indexOf(studentNum));
}
Collections.sort(list);
for(int student : list) {
System.out.println(student);
}
}
}
1. 1부터 30까지 숫자가 들어있는 list를 생성한 후
ArrayList<Integer> list = new ArrayList<>();
for(int i = 1 ; i<= 30; i++) {
list.add(i);
}
2. 과제를 제출한 학생 번호를 입력할 때마다
indexOf(studentNum)와 remove를 이용해 리스트에서 제거해주었다.
while(totalNumber-- > 0) {
int studentNum = Integer.parseInt(br.readLine());
list.remove(list.indexOf(studentNum));
}
3. 출력에서 오름차순으로 출력하라고 했기때문에 sort를 이용해 오름차순 정렬해주면 과제 제출 안한 학생의
출석번호를 구할 수 있었다.
반응형
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 2812 크게만들기 (자바풀이) (0) | 2024.07.25 |
---|---|
[백준] 1987알파벳 (0) | 2024.07.24 |
백준 [2869 달팽이는 올라가고 싶다] (1) | 2023.02.19 |
백준 [1193 분수찾기] (0) | 2023.02.18 |
백준 [3052] 나머지 (0) | 2023.02.10 |