알고리즘/알고리즘
[알고리즘] 병합정렬 (Merge sort)
i5
2024. 12. 5. 00:20
반응형
설명
병합정렬의 원리는,
1. 배열의 사이즈가 1이 될 때까지 반으로 쪼갠다
2. 사이즈가 1이 되면, 오름차순(혹은 내림차순)으로 비교 정렬하여 합친다.
3. 이것을 반복한다.
결과적으로 이것의 시간복잡도는 Nlog(N)이 된다.
핵심코드
int arr[N], trr[N];
void mergeSort(int *arr, int s, int e) {
if (s + 1 >= e) return;
int m = (s + e) / 2, i = s, j = m, k = s;
mergeSort(arr, s, m), mergeSort(arr, m, e);
while (i < m && j < e) {
// 오름차순이므로, arr[j]가 더 작으니, arr[j]를 먼저 채운다.
if (arr[j] < arr[i]) trr[k++] = arr[j++];
else trr[k++] = arr[i++];
}
// 위를 거쳤는데도 아직까지 i가 m보다 작다면, 아직 i가 덜 합쳐진 것이다. 따라서 arr[i]를 trr[i]로 합쳐준다.
while (i < m) trr[k++] = arr[i++];
while (j < e) trr[k++] = arr[j++];
// arr배열을 업데이트 해준다.
for (i = s; i < e; ++i) arr[i] = trr[i];
}
소스코드 (C++)
#include <stdio.h>
constexpr int N = 10;
// arr은 정렬하고자하는 배열
// trr는 병합정렬을 위한 임시 배열
int arr[N], trr[N];
void mergeSort(int *arr, int s, int e) {
if (s + 1 >= e) return;
int m = (s + e) / 2, i = s, j = m, k = s;
mergeSort(arr, s, m), mergeSort(arr, m, e);
while (i < m && j < e) {
if (arr[j] < arr[i]) trr[k++] = arr[j++];
else trr[k++] = arr[i++];
}
while (i < m) trr[k++] = arr[i++];
while (j < e) trr[k++] = arr[j++];
for (i = s; i < e; ++i) arr[i] = trr[i];
}
int main(void) {
int a[] = { 10, 1, 3, 2, 5, 4, 6, 9, 7, 8 };
mergeSort(a, 0, N);
for (int i = 0; i < N; i++) {
printf("%d ", a[i]);
}
printf("\n");
return 0;
}
출력화면
1 2 3 4 5 6 7 8 9 10
소스코드 (C++) (구조체 선언 후 <연산자 재정의하는 경우)
#include <stdio.h>
constexpr int N = 10;
// arr은 정렬하고자하는 배열
// trr는 병합정렬을 위한 임시 배열
struct Product {
int id;
int price;
bool operator<(const Product&t) const {
return price < t.price;
}
} arr[N], trr[N];
void mergeSort(Product *arr, int s, int e) {
if (s + 1 >= e) return;
int m = (s + e) / 2, i = s, j = m, k = s;
mergeSort(arr, s, m), mergeSort(arr, m, e);
while (i < m && j < e) {
if (arr[j] < arr[i]) trr[k++] = arr[j++];
else trr[k++] = arr[i++];
}
while (i < m) trr[k++] = arr[i++];
while (j < e) trr[k++] = arr[j++];
for (i = s; i < e; ++i) arr[i] = trr[i];
}
int main(void) {
Product a[] = {
{1, 10},
{2, 1},
{3, 3},
{4, 2},
{5, 5},
{6, 4},
{7, 6},
{8, 9},
{9, 7},
{10, 8}
};
mergeSort(a, 0, N);
for (int i = 0; i < N; i++) {
printf("%d ", a[i].price);
}
printf("\n");
return 0;
}
출력화면
1 2 3 4 5 6 7 8 9 10
관련 문제
백준 2751번 https://www.acmicpc.net/problem/2751
정올 3519번 https://jungol.co.kr/problem/3519
반응형