inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

11.7 선택 정렬 문제 풀이

11.7 선택정렬함수

171

choijeong1615

작성한 질문수 5

0

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]); } }
}
 
첫번째 for문 밑에 min_idx=i를 안쓰고 위에 처럼 코드를 써도 똑같이 출력될줄 알았는데 아니네요..(제 의도는 시작할 때 첫번째 원소를 최솟값이다! 라고 정해놓고 하려했습니다.)
이유를 잘 모르겠습니다..(혹시 변수 min_idx의 범위 때문인가요?)

c

답변 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으로 초기화해줘야 하는지 명확해질거라 생각합니다.

 

이해가 가셨으면 좋겠네요 :)

혹시라도 이해가 안가시거나 추가적인 질문이 있으시다면 언제든 댓글 달아주세요.

 

감사합니다.

0

choijeong1615

감사합니다

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