Algorithm/Theory
[자바] 단순 선택 정렬과 단순 삽입 정렬
hyunipad
2022. 1. 22. 17:37
반응형
단순 선택 정렬
단순 선택 정렬이란 배열중 가장 작은 요소를 선택해 알맞은 위치로 옮겨서 정렬하는 단순한 알고리즘입니다.
아래의 배열에서 가장 작은 요소인 1을 선택해 첫 번째 위치인 6과 교환합니다.
그다음 작은 요소인 4를 선택해 두 번째 위치는 5와 교환합니다.
- 아직 정렬하지 않은 요소중에서 가장 작은 값을 선택합니다.
- 선택한 가장 작은 값과 아직 정렬하지 않은 부분의 첫 번째 위치의 요소와 교환합니다.
단순 선택 정렬은 위와 같은 작업을 N-1회 반복하여 정렬하는 알고리즘입니다.
단순 선택 정렬을 코드로 구현해보겠습니다.
package selectionsort;
public class selectionSort {
static void swap(int[] a, int idx1, int idx2) {
int temp = a[idx1];
a[idx1] = a[idx2];
a[idx2] = temp;
}
static void selectionSort(int[] a, int N) {
for(int i = 0 ; i < N -1 ; i++) {
int min = i;
for(int j = i + 1 ; j < N ; j++) {
if(a[j] < a[min]) {
min = j;
}
}
swap(a, i, min);
}
}
}
작업을 N - 1회 반복하여 가장 작은 요소를 셀렉트하여 첫 번째 요소와 교환하는 아주 단순한 정렬 알고리즘입니다.
단순 삽입 정렬
단순 삽입 정렬이란 선택한 요소를 알맞은 위치에 삽입하는 작업을 반복하는 알고리즘입니다.
단순 선택 정렬과 비슷하게 보일 수 있지만 단순 삽입 정렬은 차례대로 요소를 선택하여 앞쪽에 적절한 위치에 삽입한다는 점이 다릅니다. 아래의 그림을 참고해주세요.
단순 삽입 정렬은 단순 선택 정렬보다는 조금 더 복잡합니다.
그 이유는 요소를 선택하여 알맞은 위치에 옮길 때, 알맞은 위치를 찾기 위해서 아래의 두 조건을 만족할 때까지 인접한 요소들과 교환해나가는 작업을 반복해야 합니다.
- 정렬된 열의 왼쪽 끝에 도달
- 작거나 같은 요소를 발견
작거나 같은 요소를 오름차순 기준입니다. 내림차순이라면 크거나 같은 요소가 되겠습니다.
위의 내용을 바탕으로 코드를 구현해보겠습니다.
package insertionsort;
public class insertionSort {
static void swap(int[] a, int idx1, int idx2) {
int temp = a[idx1];
a[idx1] = a[idx2];
a[idx2] = temp;
}
static void insertionSort(int[] a, int N) {
for (int i = 1; i < N; i++) { // 두번째 요소부터 시작
int j;
int temp = a[i];
for (j = i; j > 0 && a[j - 1] > temp; j--) {
a[j] = a[j - 1]; // 왼족의 요소와 교환
}
a[j] = temp;
}
}
}
두 번째 요소부터 작업을 시작하여 반복문이 만족하지 않을 때까지 왼쪽의 요소와 교환합니다.
첫 번째 조건인 j > 0이 의미하는 것은 정렬된 열의 왼쪽 끝에 도달하지 않았다는 것이고
두 번째 조건인 a [j - 1] > temp는 작거나 같은 요소를 발견하지 못했다는 것입니다.
그리고 조건이 만족하지 않았을 때 교환 작업이 종료되므로 위에서 설명해드린 두 조건을 만족하는 것입니다.
반응형