Algorithm/정렬
[C++] 선택 정렬(Selection Sort)
Potato potage
2021. 8. 23. 21:52
반응형
선택 정렬
- 배열에서 최소값을 발견한 다음, 이 최소값을 배열의 첫번째 요소와 교환한다.
- 다음에는 첫번째 요소를 제외한 나머지 요소들 중에서 가장 작은 값을 선택하고 이를 두번째 요소와 교환한다.
- 이 절차를 (개수 - 1)만큼 되풀이한다.
선택 정렬의 과정
구현 코드
#include <iostream>
using namespace std;
void swap(int& a, int& b) {
int tmp;
tmp = a;
a = b;
b = tmp;
}
void SelectionSort(int* arr, int len) {
int min_idx;
for (int i = 0; i < len - 1; i++) {
min_idx = i;
for (int j = i + 1; j < len; j++) {
if (arr[min_idx] > arr[j]) {
min_idx = j;
}
}
swap(arr[min_idx], arr[i]);
}
}
int main(void) {
int arr[6] = { 5,3,8,1,2,7 };
int len = 6;
for (int i = 0; i < len; i++) {
cout << arr[i] << " ";
}
cout << endl;
SelectionSort(arr, len);
for (int i = 0; i < len; i++) {
cout << arr[i] << " ";
}
return 0;
}
시간 복잡도
- (n-1) + (n-2) + .... + 1 = n(n-2)/2 = O(n^2)
반응형