https://www.acmicpc.net/problem/5597
5597번: 과제 안 내신 분..?
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다. 교수님이 내준 특별과제를 28명이 제출했는데,
www.acmicpc.net
c++로 백준 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
<문제 풀이>
1. int형의 배열을 선언한다. 1부터 30까지 저장한다.
2. int형의 배열을 선언한다. 28개의 숫자를 입력받아 저장한다.
3. 두 배열의 값을 비교해 같은 값이 있으면 그 값을 0으로 바꿔 저장한다.
4. 배열의 값이 0이 아니면 출력한다.
이 문제에서 고려해야할 점: 배열에서 없는 숫자를 골라내는 코드를 짤 때 더 생각하게 되었다. 처음에는 bool형을 사용해 조건에 따라 true가 되면 겹치지 않은 숫자가 출력되도록 만들었지만 어떠한 오류때문에 컴파일 오류가 나 문제가 원하는 대로 답을 출력하지 못했다. (이유는 아직 알지 못했다..) 해결책으로, 두 배열을 비교해 같은 수가 있으면 그곳에 0을 저장하고, 배열의 값이 0이 아니면 그 값을 출력하도록 했다.
코드는 다음과 같다.
'C++' 카테고리의 다른 글
[백준 알고리즘] 2908번 : 상수, c++ (0) | 2022.01.10 |
---|---|
[백준 알고리즘] 10951번 : A+B - 4, c++ (0) | 2022.01.09 |
[백준 알고리즘] 11654번 : 아스키 코드, c++ (0) | 2022.01.08 |
[백준 알고리즘] 11720번 : 숫자의 합, c++ (0) | 2022.01.07 |
[백준 알고리즘] 1546번 : 평균, c++ (0) | 2022.01.07 |