Сортировка слиянием - EcsFlash/DataTypes GitHub Wiki
- Исходный массив делится на две части
- Для полученных подмассивов выполняется шаг 1 до тех пор пока не получатся просто элементы.
- Полученные элементы сравниваются между собой и выстраиваются в нужном порядке.
- Полученные пары сливаются в четверку, попутно сортируясь
- Четверки сливаются в восьмерки и тд пока не будет получен отсортированный исходный массив
┌────────────┬───────────────┬────────────────┬──────────────┐
│ Сложность │ Лучший случай │ Средний случай │ Худший случай│
├────────────┼───────────────┼────────────────┼──────────────┤
│ Время │ O(n log n) │ O(n log n) │ O(n log n) │
├────────────┼───────────────┼────────────────┼──────────────┤
│ Память │ O(n) │ O(n) │ O(n) │
└────────────┴───────────────┴────────────────┴──────────────┘
func mergeSort(items []int) []int {
if len(items) < 2 {
return items
}
first := mergeSort(items[:len(items)/2])//берем левую часть массива
second := mergeSort(items[len(items)/2:])//берем правую часть массива
return merge(first, second)
}
func merge(a []int, b []int) []int {
final := []int{}
i := 0
j := 0
for i < len(a) && j < len(b) { \\это типо while
if a[i] > b[j] {
final = append(final, a[i])
i++
} else {
final = append(final, b[j])
j++
}
}
for ; i < len(a); i++ { \\for без секции инициализации
final = append(final, a[i])
}
for ; j < len(b); j++ { \\for без секции инициализации
final = append(final, b[j])
}
return final
}
C++
#include <bits/stdc++.h>
using namespace std;
// Merges two subarrays of arr[].
// First subarray is arr[left..mid]
// Second subarray is arr[mid+1..right]
void merge(vector<int>& arr, int left,
int mid, int right)
{
int n1 = mid - left + 1;
int n2 = right - mid;
// Create temp vectors
vector<int> L(n1), R(n2);
// Copy data to temp vectors L[] and R[]
for (int i = 0; i < n1; i++)
L[i] = arr[left + i];
for (int j = 0; j < n2; j++)
R[j] = arr[mid + 1 + j];
int i = 0, j = 0;
int k = left;
// Merge the temp vectors back
// into arr[left..right]
while (i < n1 && j < n2) {
if (L[i] <= R[j]) {
arr[k] = L[i];
i++;
}
else {
arr[k] = R[j];
j++;
}
k++;
}
// Copy the remaining elements of L[],
// if there are any
while (i < n1) {
arr[k] = L[i];
i++;
k++;
}
// Copy the remaining elements of R[],
// if there are any
while (j < n2) {
arr[k] = R[j];
j++;
k++;
}
}
// begin is for left index and end is right index
// of the sub-array of arr to be sorted
void mergeSort(vector<int>& arr, int left, int right)
{
if (left >= right)
return;
int mid = left + (right - left) / 2;
mergeSort(arr, left, mid);
mergeSort(arr, mid + 1, right);
merge(arr, left, mid, right);
}
// Function to print a vector
void printVector(vector<int>& arr)
{
for (int i = 0; i < arr.size(); i++)
cout << arr[i] << " ";
cout << endl;
}
// Driver code
int main()
{
vector<int> arr = { 12, 11, 13, 5, 6, 7 };
int n = arr.size();
cout << "Given vector is \n";
printVector(arr);
mergeSort(arr, 0, n - 1);
cout << "\nSorted vector is \n";
printVector(arr);
return 0;
}