Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 프로그래머스
- 공부
- Redux
- 협업
- 알고리즘
- 백준
- C++
- 정렬
- 파이썬
- error
- Java
- 토이프로젝트
- codeup
- 코드업
- 분할메모리할당
- 일상
- CPU 스케줄링
- react-redux
- 리덕스장바구니
- 자료구조
- 스프링
- Spring
- memory
- Operating System
- 기초100제
- js to ts
- react
- 타입스크립트
- OS
- web
Archives
- Today
- Total
감자튀김 공장🍟
[C++] 선택 정렬(Selection Sort) 본문
반응형
선택 정렬
- 배열에서 최소값을 발견한 다음, 이 최소값을 배열의 첫번째 요소와 교환한다.
- 다음에는 첫번째 요소를 제외한 나머지 요소들 중에서 가장 작은 값을 선택하고 이를 두번째 요소와 교환한다.
- 이 절차를 (개수 - 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)
반응형
'Algorithm > 정렬' 카테고리의 다른 글
[python] 버블 정렬(Bubble sort) (0) | 2022.03.19 |
---|---|
[C++] 쉘 정렬 (Shell Sort) (0) | 2021.08.27 |
[C++] 버블 정렬(Bubble Sort) (0) | 2021.08.27 |
[C++] 삽입 정렬(Insertion Sort) (0) | 2021.08.24 |
[C++] 힙 & 힙 정렬(Heap & Heap Sort) (0) | 2021.08.22 |
Comments