D.evelop [CS]/Algorithm
[알고리즘 이론] 정렬 Sort - 2-3. 비교 기반 알고리즘 (삽입 정렬)
Danne
2024. 4. 24. 09:54
정렬 Sort
1. 기본 개념
2. 비교 기반 알고리즘
1) 선택 정렬
2) 버블 정렬
3) 삽입 정렬
4) 셸 정렬
💡예시에 대한 가정
- 입력 크기 n
- 입력 배열 A[0…. n-1]
- 입력 데이터 : 양의 정수
- 정렬 방식 : 오름차순 (1, 2, 3, 4,…)
2-3) 삽입 정렬 (Insertion sort)
- 주어진 데이터를 하나씩 뽑은 후,
이미 나열된 데이터들이 항상 정렬된 상태를 갖도록 바른 위치를 찾아 뽑은 데이터를 삽입해서 나열하는 방식 - 정렬 부분 A[0…k-1] 과 미정렬 부분 A[k…n-1] 으로 구분해서 처리
- 정렬 과정
- 미정렬 부분 A[k…n-1]에서 1번째 데이터를 뽑아
- 정렬 부분 A[0…k-1]에서 올바른 자리에 삽입
입력 데이터 A [10, 30, 40, 20, 70, 50, 60]
1️⃣. 입력데이터를 정렬부분과 미정렬 부분으로 나눈다.
2️⃣. 미정렬 부분의 첫번째 데이터 20을 뽑는다.
3️⃣. 뽑힌 데이터 20을 정렬부분의 가장 오른쪽 (=정렬 부분의 가장 큰 값, 20과 가장 인접한 쪽)부터 비교하여 진입한다.
4️⃣. 비교할 데이터가 20보다 작으면 교환하지 않고 단계를 종료한다.
5️⃣. 2️⃣ ~ 4️⃣ 과정을 반복한다.
3. 특징
- 성능 : O(n²)
- 제자리 정렬 알고리즘 : 입력 배열 A 이외 상수개(i, j, val) 의 저장 공간만 필요
- 안정적 정렬 알고리즘
- 입력 데이터의 원래 순서에 민감
- 역순의 경우에는 O( n²)
- 제 순서대로 거의 정렬되었으면 O(n)
[JS code]
function insertionSort(A) {
const n = A.length;
for (let i = 1; i < n; i++) { // 1, …, (n-1)까지 (n-1)번 반복. A[0] 정렬 부분이므로 건너뜀
let val = A[i]; // 미정렬 부분 첫 번째 데이터를 선택. val에 대입
for (let j = i; j > 0 && A[j - 1] > val; j--) { // 정렬된 부분에서 비교를 시작합
A[j] = A[j - 1]; // 정렬 부분의 A[j-1]이 val보다 크면 뒤로 한 칸 이동
}
A[j] = val; // 찾아진 위치에 선택된 데이터를 삽입
}
return A;
}
반응형