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
오랜만에 푸는 파이썬은 역시나 리셋 ㄹㅇㅋ ㅋ
오랜만이라 풀이를 안보면 아예 기억이 안나는 수준이라 리뷰하면서 리마인드를 하겠다
일단 1~30의 번호를 집합 set으로 세팅
set(range(1,31))
이후 표준 입력으로 받은 모든 데이터를 공백 기준으로 분리 시켜서 리스트로 만들어버림
그 다음에 sorted메서드로 차집합 계산 후 정렬하여 출력
집합끼리는 연산이 가능하다는 사실은 나에겐 새로운 관점이였던 듯
import sys
# 전체 학생 번호 (1번부터 30번까지)
all_students = set(range(1, 31))
# 입력받은 제출한 학생 번호
submitted_students = set(map(int, sys.stdin.read().split()))
# 제출하지 않은 학생 번호 계산
missing_students = sorted(all_students - submitted_students)
print(all_students)
# 결과 출력
for student in missing_students:
print(student)
잘 지내시는지요 요즘 뭐하시나용