11.7 선택정렬함수
171
작성한 질문수 5
답변 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으로 초기화해줘야 하는지 명확해질거라 생각합니다.
이해가 가셨으면 좋겠네요 :)
혹시라도 이해가 안가시거나 추가적인 질문이 있으시다면 언제든 댓글 달아주세요.
감사합니다.
Export template 안됨
1
63
2
완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.
1
88
3
main 함수에서 왜 int만 선언이 되는걸까요
1
78
2
8비트 2진수 변환시 왜 1을 더해야하나요?
1
75
2
혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?
1
78
1
프로토타입과 함수간의 인자 불일치
1
87
2
12.12 헤더 관련 질문
1
74
2
Visual Studio Community 2026 사용 문의
1
169
2
Q. 15:30, 부호가 있는 8비트 정수 질문
1
71
2
getchar(), putchar()
1
111
3
강의자리ㅛ
1
93
2
비주얼스튜디오코드로 공부해도 상관없나요?
1
127
2
소스파일안에 여러 파일
1
87
2
F5와 F7의 차이
1
90
2
c = TWO * (a+b); 에서 a와 b는?
1
67
2
; 세미콜론을 붙이는 기준에 문의
1
78
1
Step over 기능 문의
1
64
2
2.6 강의 따옴표 출력 규칙 문의
1
87
2
int main 함수 관련 오류 문의
1
76
2
13.4 words[0]
0
73
2
11.7 함수를 구현해 봤습니다.
1
67
2
11.6 직접 strcmp와 strncmp를 구현해 보았습니다.
1
71
2
11.6 my_strcat과 my_strncat을 구현해봤습니다.
1
60
2
11.6 fit_str함수를 구현해 봤습니다.
1
59
2





