선택정렬 코드리뷰 가능하신가요?
230
작성자 없음
작성한 질문수 0

스스로 디버깅 계속해보면서 구현해내는데는 성공했습니다만 정답이라고 할 수 있는 답안인가요?
답변 1
2
안녕하세요? 질문&답변 도우미 Soobak 입니다.
제 개인적인 의견은, 학습 단게에서부터 스스로 디버깅을 하시며 정렬 알고리즘을 잘 구현하셨다고 생각합니다.
다만, '선택 정렬' 이라고 불리는 정렬 방식은, 각 단계에서 '배열의 남은 부분 중 가장 작은 요소를 선택' 하여 현재 위치로 이동시키는 것이 핵심적인 부분입니다.
이를 통해, 불필요한 교환을 최소화하고, 각 단계에서 배열이 점진적으로 정렬됩니다.
반면, 질문자님께서 구현하신 정렬 알고리즘은 현재 위치 (i) 와 그 이후의 모든 요소를 비교하며, 작은 값을 발견할 때마다 두 값을 교환하기 때문에 여러 번 교환이 발생할 수 있습니다.
따라서, 불필요하게 많은 교환이 발생하게 됩니다.
하지만, 처음 말씀드렸던 것 처럼, 문법 학습단계에서부터 정렬 알고리즘을 스스로 구현해내셨다는 점, 그리고 디버깅도 진행하시며 노력하신 그 과정을 생각해보았을 때 충분히 잘 작성하신 코드라고 생각합니다.
표준 선택 정렬 알고리즘의 코드를 첨부드리오니, 참고해보시면 도움이 되실 것 같습니다.
for (int i = 0; i < length - 1; i++)
{
int min_index = i; // 현재 위치에서 최소값의 인덱스를 저장
for (int j = i + 1; j < length; j++)
{
if (array[j] < array[min_index])
{
min_index = j; // 최소값의 인덱스 업데이트
}
}
// 최소값을 현재 위치로 교환
int temp = array[i];
array[i] = array[min_index];
array[min_index] = temp;
}
교재 있나요?
1
133
2
11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)
1
88
3
using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다
1
101
2
cstr직접구현
0
115
3
BubbleSort
1
77
2
숙제 마지막 부분
1
78
2
강의와 똑같이 진행했는데 링킹 에러가 발생합니다.
1
93
2
수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??
1
161
2
공변반환형 관련 문의 드립니다.
1
89
2
170강 유니크 포인터에대해 질문있습니다
1
80
1
섹션 5 퀴즈의 답이 이상합니다
1
83
2
이중포인터와 배열이 이해가 안됩니다.
1
158
2
5분 17~5분 34초 객체 잘림 질문
1
78
1
Resource.h 코드 알려주세요
1
71
1
char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다
1
94
2
화면좌측 숫자 보이기
1
114
1
화면 좌측 숫자 보이기
0
66
1
처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??
1
137
3
46강 string 버퍼 질문입니다
1
80
2
프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.
1
123
2
[] 범위 검사시 assert 사용 관련 질문
1
89
2
Lecture 클래스 멤버변수 명명 관련
0
89
2
프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요
0
73
1
noexcept과 throw()
1
81
2





