sdfsdf

 avatar
unknown
plain_text
a year ago
1.2 kB
6
Indexable
#include<stdio.h>
#include<conio.h>
void merge(int arr[], int left, int right, int mid)
{
    int Lsize = mid - left + 1;
    int Rsize = right - mid, i;

    int leftArr[100], rightArr[100];

    for (i = 0; i < Lsize; i++)
	leftArr[i] = arr[i + left];

    for (i = 0; i < Rsize; i++)
	rightArr[i] = arr[i + mid + 1];

    int j = 0, k = left;
    i = 0;

    while (i < Lsize && j < Rsize)
    {
	if (leftArr[i] < rightArr[j])
	    arr[k++] = leftArr[i++];
	else
	    arr[k++] = rightArr[j++];
    }

    while (i < Lsize)
	arr[k++] = leftArr[i++];

    while (j < Rsize)
	arr[k++] = rightArr[j++];
}

void mergeSort(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, right, mid);
}

int main()
{
    int arr[100], size;
    clrscr();
    printf("\nEnter size ");
    scanf("%d", &size);
    printf("\nEnter array\n");
    for (int i = 0; i < size; i++)
	scanf("%d", &arr[i]);

    mergeSort(arr, 0, size - 1);

    printf("Sorted array\n");
    for (i = 0; i < size; i++)
	printf("%d ", arr[i]);
    getch();

    return 0;
}
Editor is loading...
Leave a Comment