有人能告訴我下面的mergesort實現有什麼問題嗎?我一直在抓我的頭幾個小時..有人能告訴我我的mergesort有什麼問題嗎?
void merge(int arr[], int low, int mid, int high)
{
int i = 0;
int j = 0;
int k = 0;
int buf1[1024];
int buf1Length = mid - low + 1;
int buf2[1024];
int buf2Length = high - (mid + 1) + 1;
for (i = low; i <= mid; i++)
{
buf1[j++] = arr[i];
}
for (i = mid + 1; i <= high; i++)
{
buf2[k++] = arr[i];
}
i = 0;
j = 0;
k = 0;
while (j < buf1Length && k < buf2Length)
{
if (buf1[j] <= buf2[k])
{
arr[i++] = buf1[j++];
}
else
{
arr[i++] = buf2[k++];
}
}
while (j < buf1Length)
arr[i++] = buf1[j++];
while (k < buf2Length)
arr[i++] = buf2[k++];
}
void mergeSort(int arr[], int low, int high)
{
int mid;
if (low < high)
{
mid = (low + high)/2;
mergeSort(arr, low, mid);
mergeSort(arr, mid + 1, high);
merge(arr, low, mid, high);
}
}
int main()
{
int i;
int arr[] = {6, 7, 2, 4, 9, 8};
mergeSort(arr, 0, 5);
printf("\n\n results: \n");
for (i = 0; i < 6; i++)
{
printf("%d ", arr[i]);
}
printf("\n\n\n");
return 0;
}
如果這是作業,請確保您在此前面。 – 2011-02-14 03:19:24