- Python
- Image_classification
- 티스토리챌린지
- Linux
- codingTest
- 2023_1st_Semester
- Database_Design
- Artificial_Intelligence
- programmers
- cloud_computing
- Unix_System
- 자격증
- Operating_System
- Java
- datastructure
- Algorithm
- 오블완
- pytorch
- C
- Univ._Study
- c++
- Baekjoon
- tensorflow
- Android
- Kubernetes
- 리눅스마스터2급
- Personal_Study
- app
- SingleProject
- study
코딩 기록 저장소
[백준/Java] 5597번: 과제 안 내신 분..? 본문
문제 정보
제목 : 과제 안 내신 분..?
번호 : 5597번
사용 언어 : Java
문제 링크
https://www.acmicpc.net/problem/5597
5597번: 과제 안 내신 분..?
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다. 교수님이 내준 특별과제를 28명이 제출했는데,
www.acmicpc.net
시간 제한 | 메모리 제한 |
1 초 | 128 MB |
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
입출력 예제

나의 풀이
30명의 학생이 있으므로 count 변수에는 30을 저장합니다. 그리고 길이가 30인 배열을 생성하여 1부터 30까지 번호를 저장합니다. count가 2보다 클 동안 반복하는 while루프를 생성하여 한줄을 입력받아 정수형으로 형변환한 후 n에 저장합니다. n-1인덱스에 있는 번호를 0으로 변경하고 count는 -1합니다. while 루프가 끝나면 출력을 위해 30번 반복하는 for루프를 생성합니다. if문을 이용해 num[i]의 값이 0이 아니면 출력합니다.
코드
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.Arrays;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int count = 30;
int[] num = new int[30];
for(int i =0;i<30;i++)
{
num[i] = i+1;
}
while(count>2)
{
int n = Integer.parseInt(br.readLine());
num[n-1] = 0;
count--;
}
for(int i =0;i<30;i++)
{
if (num[i] != 0)
bw.write( num[i] +"\n");
}
bw.flush();
bw.close();
br.close();
}
}
'백준 > 1차원 배열 (완료)' 카테고리의 다른 글
[백준/Java] 10811번: 바구니 뒤집기 (2) | 2023.05.10 |
---|---|
[백준/Java] 3052번: 나머지 (0) | 2023.05.10 |
[백준/Java] 10813번: 공 바꾸기 (0) | 2023.05.08 |
[백준/Java] 10810번: 공 넣기 (0) | 2023.05.08 |
[백준/Java] 10818번: 최소, 최대 (4) | 2023.05.04 |