728x90
2023.07.28 문제 풀이 결과 : 오답
문제
X대학 M교수님은 프로그래밍 수업을 맡고 있다. 교실엔 학생이 30명이 있는데, 학생 명부엔 각 학생별로 1번부터 30번까지 출석번호가 붙어 있다.
교수님이 내준 특별과제를 28명이 제출했는데, 그 중에서 제출 안 한 학생 2명의 출석번호를 구하는 프로그램을 작성하시오.
입력
입력은 총 28줄로 각 제출자(학생)의 출석번호 n(1 ≤ n ≤ 30)가 한 줄에 하나씩 주어진다. 출석번호에 중복은 없다.
출력
출력은 2줄이다. 1번째 줄엔 제출하지 않은 학생의 출석번호 중 가장 작은 것을 출력하고, 2번째 줄에선 그 다음 출석번호를 출력한다.
나의 풀이
#include <iostream>
#include <vector>
int main() {
int input =28;
std::vector<int> num(30, 0);
for (int i = 0; i < input; i++) {
int value;
std::cin >> value;
num[value - 1] = 1;
}
std::cout << "제출하지 않은 학생의 출석번호: ";
for (int i = 0; i < 30; i++) {
if (num[i] == 0) {
std::cout << i + 1 << std::endl;
}
}
return 0;
}
GPT의 풀이
#include <iostream>
#include <set>
using namespace std;
int main() {
set<int> submitted_numbers;
// 입력 받기
for (int i = 0; i < 28; ++i) {
int number;
cin >> number;
submitted_numbers.insert(number);
}
// 1부터 30까지의 출석번호 중에서 제출하지 않은 두 개의 출석번호 찾기
int missing_number1 = 0, missing_number2 = 0;
for (int number = 1; number <= 30; ++number) {
if (submitted_numbers.find(number) == submitted_numbers.end()) {
if (missing_number1 == 0)
missing_number1 = number;
else {
missing_number2 = number;
break; // 두 개의 출석번호를 모두 찾았으면 반복 종료
}
}
}
// 결과 출력
cout << missing_number1 << endl;
cout << missing_number2 << endl;
return 0;
}
오답 원인 분석
set은 기본적으로 오름차순 정렬이 되어 반복문으로 요소를 받아올때 첫번째 값이 가장 낮은 숫자임을 확실하게 알 수 있지만 나의 코드는 정렬이 되어있지 않다.
728x90
'코딩테스트' 카테고리의 다른 글
[백준][C++] 2720 문제 : 세탁소 사장 동혁 (0) | 2023.08.08 |
---|---|
[백준][C++] 5622 문제 : 다이얼 (0) | 2023.08.01 |
[백준][C++] 10813 문제 : 공 바꾸기(swap) (0) | 2023.07.27 |
[백준][C++] 10950 문제 : A+B -3 (0) | 2023.07.02 |
[백준][C++] 2480 문제 : 주사위 세개 (0) | 2023.06.30 |