0
我陷入heapSort。我有一些代碼,但我認爲它很不對,因爲我很難編譯它。有什麼建議麼?堆排序應該相當容易實現,但我有一堆的語法錯誤。這裏是我的代碼:試圖執行HeapSort
/* Framework for Heap Sort
* CS333 Spring 2011
*
*/
#include <stdio.h>
#define MAX_SIZE 1000000
int data[MAX_SIZE];
int n;
int j;
int parent(int j) {
if(j==1)
return 0;
if(j%2==0)
return ((j/2)-1);
else
return ((j/2));
}
int left(int j) {
return (2 * j) + 1;
}
int right(int j) {
return (2 * j) + 2;
}
void heapify(int data[], int j) {
int l = left(j), great;
int r = right(j);
if ((data[l] > data[j]) && (l < sizeof(data))) {
great = l;
}
else {
great = j;
}
if ((data[r] > data[great]) && (r < sizeof(data))) {
great = r;
}
if (great != j) {
int temp = data[j];
data[j] = data[great];
data[great] = temp;
heapify(data, great);
}
}
int BuildMaxHeap(int data[]) {
for (int j = (sizeof(data) - 1)/2; j >= 0; j--) {
heapify(data, j);
return data;
}
}
void HeapSort(int data[]) {
BuildMaxHeap(data);
for (int j = sizeof(data); j > 0; j--) {
int temp = data[0];
data[0] = data[data.sizeof() - 1];
data[sizeof(data) - 1] = temp;
sizeof(data) = sizeof(data) - 1;
heapify(data, 0);
}
}
int main()
{
int i;
/* Read in the data */
n = 0;
while (scanf("%d", &data[n]) == 1)
++n;
/* Sort the numbers low to high */
HeapSort(data);
/* Print out the data */
for (i = 0; i < n; ++i)
printf("%d", data[i]);
}
你的錯誤是什麼? – qwertymk 2011-02-17 03:54:24
全局變量`j`不需要;在函數中使用`j`的地方,都有一個局部變量。全局變量`n`不需要;它應該在`main()`中是本地的,並傳遞給需要知道要排序的元素數目的其他函數。對一百萬個整數進行排序是一件有意義的事情 - 儘管一旦你的代碼有效,它可以處理一百萬和一千個(給予或花費額外的時間)。 – 2011-02-17 05:20:52