문제 링크
https://www.acmicpc.net/problem/5597
문제
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
정답 및 풀이
student_list = [0]*30
for i in range(28):
student = int(input())
for j in range(len(student_list)+1):
if j == student:
student_list[j-1] = student
for j in range(len(student_list)):
if student_list[j] == 0:
print(j+1)
- 리스트 초기화
- 길이가 30, 0으로 초기화
- 28명의 제출 학생 입력 받기
- j==student 이면 해당 위치에 학생 번호 기록
- 0 인 칸 출력
또 다른 풀이
student_list = [0] * 30
# 1. 28명의 학생 번호 입력받기
for _ in range(28):
student = int(input())
student_list[student - 1] = student # 바로 해당 위치에 기록
# 2. 제출하지 않은 학생(= 값이 0인 위치) 출력
for i in range(30):
if student_list[i] == 0:
print(i + 1)
새롭게 배운 내용 및 느낀점
- for 문을 너무 자주 쓰려고 하지 말고 , 조금 더 간결하게 작성하려고 노력하자.
'백준' 카테고리의 다른 글
| [백준] 10811 : 바구니 뒤집기 (Python/파이썬) (1) | 2025.09.12 |
|---|---|
| [백준] 3052 : 나머지 (Python/파이썬) (0) | 2025.09.12 |
| [백준] 10813 : 공 바꾸기 (Python/파이썬) (0) | 2025.09.11 |
| [백준] 10810 : 공 넣기 (Python/파이썬) (0) | 2025.09.10 |
| [백준] 2562 : 최댓값 (Python/파이썬) (0) | 2025.09.10 |