inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

11.7 선택 정렬 문제 풀이

구현해보았습니다.

188

fe

작성한 질문수 25

0

7:25초까지만 듣고 빈칸코드 안 보고 직접 해봤습니다.

못 푸신 분들은 참고하세요.

괜찮으시다면 피드백 부탁드립니다.

저는 7:25 이후부터 들으러 가겠습니다.

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>

void swap(int* xp, int* yp);
void printArray(int arr[], int size);
void selectionSort(int arr[], int n);

int main()
{
	int arr[] = { 77, 4, 234, 864,25,12,22,11, 999, 111 };
	int n = sizeof(arr) / sizeof(arr[0]);

	selectionSort(arr, n);

	printArray(arr, n);

	return 0;
}

void swap(int* xp, int* yp)
{
	int temp = *xp;
	*xp = *yp;
	*yp = temp;
}

void printArray(int arr[], int size)
{
	for (int i = 0; i < size; i++)
		printf("%d ", arr[i]);
}

void selectionSort(int arr[], int n)
{
	int min_idx = 0;
	int start_idx = 0;
	while(start_idx!=n) //첫 인덱스 0을 시작으로 n-1까지 돌면서 인덱스비교
	{
		for (int i = start_idx; i < n; i++) //시작 원소부터 마지막 원소까지 반복
		{
			if (arr[min_idx] > arr[i]) // 인덱스 기준으로 값을 비교하며 오름차순 정렬
				min_idx = i;
		}
		swap(&arr[min_idx], &arr[start_idx]); 
		start_idx++; // 한 주기의 sorting이 끝날 때마다 시작인덱스도 1씩 증가
		min_idx = start_idx; // 시작인덱스와 최소값인덱스를 맞춰줘야 그 기준으로 싹 다 비교함.
	}
	
}

c

답변 1

1

Hello Yeo

이 코드는 문제없이 작동하는 것 같습니다.

Export template 안됨

1

11

2

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

1

54

3

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

1

56

2

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

1

54

2

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

1

49

1

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

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

137

2

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

1

60

2

getchar(), putchar()

1

93

3

강의자리ㅛ

1

79

2

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

1

112

2

소스파일안에 여러 파일

1

75

2

F5와 F7의 차이

1

76

2

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

1

58

2

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

1

68

1

Step over 기능 문의

1

53

2

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

1

74

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

60

2

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

1

62

2

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

1

64

2

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

1

53

2

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

1

53

2