퀵 소트와 마찬가지로 면접에서 자주 나오는 문제이므로 익혀두면 좋습니다.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#include <iostream> | |
#include <vector> | |
using namespace std; | |
const int MAX = 1000000 + 1; | |
vector<int> v(MAX, 0); | |
vector<int> temp(MAX, 0); | |
// [begin, end) | |
void mergeSort(int begin, int end) | |
{ | |
if (end - begin == 1) | |
{ | |
return; | |
} | |
if (end - begin == 2) | |
{ | |
if (v[begin] > v[end - 1]) | |
{ | |
swap(v[begin], v[end - 1]); | |
} | |
return; | |
} | |
int mid = (begin + end) / 2; | |
mergeSort(begin, mid); | |
mergeSort(mid, end); | |
merge(begin, end); | |
} | |
// 전제 조건: v[begin, mid), v[mid, end)는 이미 정렬이 되어있는 상태 | |
void merge(int begin, int end) | |
{ | |
int mid = (begin + end) / 2; | |
int idx = begin; | |
int idx1 = begin; | |
int idx2 = mid; | |
while (idx1 < mid && idx2 < end) | |
{ | |
temp[idx++] = (v[idx1] < v[idx2] ? v[idx1++] : v[idx2++]); | |
} | |
while (idx1 < mid) | |
{ | |
temp[idx++] = v[idx1++]; | |
} | |
while (idx2 < end) | |
{ | |
temp[idx++] = v[idx2++]; | |
} | |
for (int i = begin; i < end; i++) | |
{ | |
v[i] = temp[i]; | |
} | |
} |
반응형
'면접 준비' 카테고리의 다른 글
데이터베이스) DBMS 키 정리 (0) | 2020.06.10 |
---|---|
데이터베이스 쿼리 실행 순서 (2) | 2020.06.07 |
삽입 정렬(Insertion Sort) 구현 (0) | 2019.10.06 |
선택 정렬(Selection Sort) 구현 (0) | 2019.10.06 |
퀵 소트(Quick Sort) STL 없이 구현 (0) | 2019.07.29 |