#include <stdio.h>
void printArary(int *a, int n)
{
for (int i = 0; i < n; i++)
{
printf("%d ", a[i]);
}
printf("\n");
}
void merge(int a[], int mid, int low, int high)
{
int i, j, k, b[100];
i = low;
j = mid + 1;
k = low;
while (i <= mid && j <= high)
{
if (a[i] < a[j])
{
b[k] = a[i];
i++;
k++;
}
else
{
b[k] = a[j];
j++;
k++;
}
}
while (i <= mid)
{
b[k] = a[i];
k++;
i++;
}
while (j <= high)
{
b[k] = a[j];
k++;
j++;
}
for (int i = 0; i <= high; i++)
{
a[i] = b[i];
}
}
void mergeSort(int a[], int low, int high){
int mid;
if (low < high){
mid = (low + high) / 2;
mergeSort(a, low, mid);
mergeSort(a, mid+1, high);
merge(a, mid, low, high);
}
}
int main()
{
int a[] = {3, 4, 33, 2, 34, 2, 3};
int n = 7;
printArary(a, n);
mergeSort(a, 0, 6);
printArary(a, n);
return 0;
}