https://www.acmicpc.net/problem/5597
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
예제 입력 1 복사
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
예제 출력 1 복사
2
8
students = [i for i in range(1, 31)] # 교실에 있는 학생들 students 리스트로 저장(리스트 컴프리헨션)
for i in range(28): # 과제 제출한 28명의 학생들 here에 저장
here = int(input())
students.remove(here) # students에서 here에 해당하는 학생들 제외
print(min(students))
print(max(students))
** 리스트 컴프리헨션(List comprehension)
- 리스트 안에 for문을 포함하여 직관적으로 나타내는 것
[i for i in 리스트 또는 범위]
[표현식 for 항목 in 반복가능객체 if 조건문]
'Algorithm > 백준' 카테고리의 다른 글
[파이썬/백준3052] 나머지 - append, % , set (0) | 2023.02.19 |
---|---|
[파이썬/백준 11720] 숫자의 합 (0) | 2023.02.18 |
[파이썬/백준 2562] 최댓값 - list.append() (1) | 2023.02.16 |
[파이썬/백준 10818] 최소, 최대 - min, max() 또는 sort() (0) | 2023.02.16 |
[파이썬/백준 10871] X보다 작은 수 (0) | 2023.02.16 |