inflearn logo
강의

Course

Instructor

Hong Jung-mo's C Programming: Learning by Doing

11.7 Solving the Selection Sort Problem

selectionSort 함수구현 1시간걸림

334

Ad Astra

9 asked

1

void swap(int* xp, int* yp);

void printArray(int arr[], int size); 

void selectionSort(int arr[], int n);

int main()

{

int arr[] = { 64, 25, 12, 22, 11 };

int n = sizeof(arr) / sizeof(arr[0]);

selectionSort(arr, n); // ascending order

printArray(arr, n);

return 0;

}

void swap(int* xp, int* yp)

{

int save = *xp;

*xp = *yp;

*yp = save;

}

void selectionSort(int arr[], int n)

{

while (n)

{

int i = 1;

int* min_idx = arr;

while (i < n)

{

min_idx = (*min_idx < *(arr + i)) ? min_idx : &arr[i];

i++;

}

swap(arr, min_idx);

arr++;

n--;

}

}

void printArray(int arr[], int size)

{

for (int i = 0; i < size; i++)

printf("Sort = %d\n", arr[i]);

}

코드 안보고 나름 깔끔하게 해봤습니다. 한시간걸렸네요. 확실히 전 강의에서 strlen()함수부터 strpbhr(), strstr()까지 직접 구현해보면서 공부해보니 나름 정리가 되는 느낌이네요. 삼항연산자 처음에 배운 뒤로 잘 쓴 적 없어서 복습겸 넣어봤습니다. 최솟값 등을 구할 때 제일인 것 같아서요.

최대한 포인터를 이용하려고 했고, 결과물은 잘 나온 것 같아요. 좋은 코드가 아니라면 피드백 부탁드립니다.

정렬 c sort

Answer 3

1

honglab

정렬은 평생 거의 한 두번 직접 구현해 보면 충분하기 때문에 몇 시간 걸려서 구현하셨다고 하더라도 이익입니다. 다만, 질문글 제목을 몇 시간 걸렸는지 적으시는 것은 

1. 무의식중에 오랜 시간을 사용해서 공부하는 것을 긍정적으로 생각하기 시작

2. 다른 학생에게 이 글이 도움되지 않으며 제목과 내용이 무관함

등의 문제가 있습니다. 이제 슬슬 초보를 벗어나고 계시기 때문에 공부/업무 효율성도 신경쓰시면 좋겠습니다.

그리고 마음 같아서는 코드 리뷰도 해드리고 싶지만 현실적으로 어려운 면이 있습니다. joy님께서 요청하셨듯이 아주 구체적이면서도 간단한 형태로 질문을 정리하셔야 딱 원하는 답을 얻으실 수 있습니다.

코드 리뷰를 요청하시기 보다는 인터넷의 다양한 모범 코드들을 보면서 자신의 코드와 비교해보는 방법을 추천합니다.

0

sohyun

고생하셨네요ㅠㅠ 

검색하시면 선택 정렬 코드가 다양하게 많이 나오기 때문에 비교해보시면 공부에 많이 도움 되실 것 같아요! 

근데 int i = 1; 이 부분은 왜 아쉽다고 생각하시는건가요? 아래 질문은 조금 더 구체적으로 설명 부탁드려도 될까요! 

0

Ad Astra

int i = 1;  이 부분 초기화가 조금 아쉬운 것 같은데 이 코드 내에서 적용시킬 수 있는 다른 심플한 방법 없을까요?

Export template 안됨

1

45

2

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

70

3

main 함수에서 왜 int만 선언이 되는걸까요

1

63

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

62

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

58

1

프로토타입과 함수간의 인자 불일치

1

81

2

12.12 헤더 관련 질문

1

63

2

Visual Studio Community 2026 사용 문의

1

149

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

65

2

getchar(), putchar()

1

96

3

강의자리ㅛ

1

85

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

119

2

소스파일안에 여러 파일

1

80

2

F5와 F7의 차이

1

82

2

c = TWO * (a+b); 에서 a와 b는?

1

63

2

; 세미콜론을 붙이는 기준에 문의

1

72

1

Step over 기능 문의

1

57

2

2.6 강의 따옴표 출력 규칙 문의

1

81

2

int main 함수 관련 오류 문의

1

71

2

13.4 words[0]

0

64

2

11.7 함수를 구현해 봤습니다.

1

65

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

67

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

57

2

11.6 fit_str함수를 구현해 봤습니다.

1

56

2