작성
·
137
0
답변 1
0
안녕하세요 :)
네, 그렇습니다.
결론부터 말씀드리자면,
min_idx는 첫 번째 for loop에서 계속 돌며 지속적으로 업데이트 되어야 합니다.
모든 수를 한 번씩 쭉 돌며 숫자를 확인해야 하기 때문입니다.
첨부하신 아래의 코드는
void selectionSort(int arr[], int n)
{
int i, j, min_idx;
min_idx = 0;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (arr[min_idx] > arr[j]) {
min_idx = j;
}
swap(&arr[i], &arr[min_idx]);
}
}
}
한 번 스캔을 쭉 해서 정렬을 하고, 그 다음 모든 수를 스캔하는 것이 아니라,
min_idx = j;
인 상태에서 다시 쭉 숫자들을 스캔하며 정렬하겠죠?
(코드를 말로 표현하자니 다소 어색하지만) 중요한 건 min_idx의 의미와
0으로 초기화해주는 이유입니다.
이를 알면 어디서 min_idx 를 0으로 초기화해줘야 하는지 명확해질거라 생각합니다.
이해가 가셨으면 좋겠네요 :)
혹시라도 이해가 안가시거나 추가적인 질문이 있으시다면 언제든 댓글 달아주세요.
감사합니다.
감사합니다