개발자 되기/코딩테스트

[백준/python] 5597번

발전하는 개발자 2023. 10. 14. 19:44
728x90
반응형

문제

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

예제 입력 2 복사

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 복사

2
8

 

풀이

# 방법1

remove로 제출한 학생의 출석 번호를 소거하여 남은 출석 번호 중 min(최소), max(최대)를 찾는다.

# 학생 출석 번호(1~30)를 리스트에 전부 집어 넣기
stu = [ i for i in range(1,31)]

# 과제를 제출한 학생의 출석 번호를 제거
for i in range(28):
    submitted = int(input())
    stu.remove(submitted)
    
# 남은 학생들의 출석 번호 중 최소와 최대를 출력
print(min(stu))
print(max(stu))

# 방법2

not in으로 학생들 중 과제를 제출하지 않은 학생들을 반복문으로 출석번호 순으로 출력

# 여러 줄을 입력받을 때 sys.stdin.readline을 sys에서 import 받아 사용 
import sys
input = sys.stdin.readline 

# 과제를 제출한 학생의 출석번호를 28번 입력받는다.
stu = [int(input()) for i in range(28)]

# 과제를 제출한 학생의 출석번호가 1에서 30 사이에 없으면 출력
for i in range(1,31):
    if i not in stu:
        print(i)

# 방법3

과제를 제출한 학생들에게는 1을, 과제를 제출하지 않은 학생들에게는 0을 부여하여 0인 학생의 출석 번호를 출력

stu = [0] * 31

for i in range(28) :
  n = int(input())
  stu[n] = 1

for i in range(1, 31) :
  if stu[i] == 0 :
    print(i)
728x90
반응형