728x90
✏️ 문제
https://www.acmicpc.net/problem/5597
5597번: 과제 안 내신 분..?
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다. 교수님이 내준 특별과제를 28명이 제출했는데,
www.acmicpc.net
✏️ 풀이방법
1. 1번부터 30번까지 수가 입력된 리스트(n) 선언
2. 28개의 제출자를 입력받은 리스트(stdno) 선언
3. 리스트(stdno)에 리스트(n)이 없는 숫자를 찾아 출력
📌 코드
n = [i for i in range(1,31)]
stdno = []
for _ in range(28):
stdno.append(int(input()))
for i in range(30):
if n[i] not in stdno:
print(n[i])
📌 결과
# 입력
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
🤔 시행착오.1
n = [i for i in range(1,31)]
stdno = []
for _ in range(28):
stdno.append(int(input()))
for i in range(28):
if stdno[i] not in n:
print(n[i])
- 리스트 n에 는 이미 다 포함되어있는 것을 비교하도록 해서 아무것도 출력되지 않는다.
- 포함연산자를 확인하는데 있어서 리스트(n)과 리스트(stdno)의 위치를 잘 확인해야한다.
🤔 시행착오.2
n = [i for i in range(1,31)]
stdno = []
for _ in range(28):
stdno.append(int(input()))
for i in range(28):
if n[i] not in stdno:
print(n[i])
- 출력되는 값은 맞는 것 처럼 보이지만 두번째 for문에서 28까지 밖에 확인하지 않아 리스트n의 29,30이 포함연산자가 수행되지 않았다.
- 범위는 30까지 비교해야 리스트(n)에 있는 모든 숫자를 비교할 수 있다.
'Python > online judge' 카테고리의 다른 글
백준 [2903.중앙 이동 알고리즘] | Python (0) | 2023.12.28 |
---|---|
백준 [2869.달팽이는 올라가고 싶다] | Python (0) | 2023.12.13 |
백준 [10811.바구니뒤집기] | Python (0) | 2023.11.30 |
백준 [10810.공 넣기] | Python (0) | 2023.11.29 |
백준 [5622.다이얼] | Python (0) | 2023.11.29 |