728x90
반응형
SMALL
문제
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
풀이 1
Array를 사용해서 풀기
import Foundation
var students: [Int] = []
var numbers = [Int](1...30)
for _ in 0...27 {
let num = Int(readLine()!)!
students.append(num)
}
students.sort()
for num in numbers {
if !students.contains(num) {
print(num)
}
}
풀이 2
중복된 번호는 없다 -> Set 사용
var students: Set<Int> = []
for _ in 0...27 {
let input = Int(readLine()!)!
students.insert(input)
}
for i in 1...30 {
if !students.contains(i) {
print(i)
}
}
728x90
반응형
LIST
'Algorithm' 카테고리의 다른 글
[Algorithm] 백준 10811번 바구니 뒤집기 (0) | 2023.11.06 |
---|---|
[Algorithm] 백준 3052번 나머지 (1) | 2023.11.06 |
[알고리즘]백준 10813번 : 공 바꾸기 (1) | 2023.10.23 |
[알고리즘] 백준 10810번 : 공 넣기 (1) | 2023.10.22 |
[알고리즘] 백준 2562 번 : 최댓값과 Index (0) | 2023.10.22 |