Я новичок в C++ и пытаюсь разработать код для сортировки слияния. Я тестировал его с помощью массива выборок размером 5, но ответ, который выдает код, неверен. Я не могу понять, что происходит не так. Вот мой код:Реализация сортировки слияния
#include <iostream>
#include <cstring>
#include <sstream>
#include <fstream>
#include <iomanip>
using namespace std;
void merge(int, int, int, int*);
void merge_sort(int low, int high, int* p){
int pivot;
static int i(1);
if (high>low)
{
cout << "calling merge_sort: "<<i<<endl; i++;
pivot = low + ((high - low)/2);
cout << pivot << endl;
merge_sort(low, pivot, p);
merge_sort(pivot+1, high, p);
merge(low, pivot, high, p);
}
}
void merge(int l, int pi, int h,int* arr)
{
int start = l;
int mid = pi+1;
while((start<=pi)&&(mid <=h)){
if (arr[start] > arr[mid])
{
int temp = arr[mid];
arr[mid] = arr[start];
arr[start] = temp;
mid++;
}
else
start++;
}
}
int main()
{
int a[] = {2, 42, 3, 7, 1};
merge_sort(0, 4, a);
for (int i = 0; i<=4 ; i++)
cout << a[i] << endl;
return (0);
}
Выход следующим образом:
calling merge_sort: 1
2
calling merge_sort: 2
1
calling merge_sort: 3
0
calling merge_sort: 4
3
1
3
7
2
42
Я видел некоторые коды для реализации сортировки слияния на StackOverflow, но они используют другой временный массив, который я хочу, чтобы избежать.
Любая помощь очень ценится при сортировке этой проблемы.
Если вам нужна информация о * в месте * сливаться реализация - http://stackoverflow.com/questions/2571049/how- to-sort-in-place-using-the-merge-sort-algorithm – SChepurin