#include<stdio.h>
int swap(int *a,int *b){
int tmp;
tmp=*a;
*a=*b;
*b=tmp;
}
void heapify(int a[],int n,int i){
int largest =i;
int left=2*i+1;
int right=2*i+2;
while(left<=n&&a[left]>a[largest]){
largest=left;
}
while(right<=n&&a[right]>a[largest]){
largest=right;
}
if(largest!=i){
swap(&a[largest],&a[i]);
heapify(a,n,largest);
}
}
int heapSort(int a[],int n){
int i;
for(i=n/2-1;i>=0;i--){
heapify(a,n,i);
}
for(i=n;i>=0;i--){
swap(&a[0],&a[i]);
heapify(a,n,0);
}
}
void printlist(int A[],int len){
int i;
for(i=0;i<len;i++){
printf(" %d",A[i]);
}
printf("\n");
}
int main(){
int a[]={1,5,4,6,3,9,7};
int len=sizeof(a)/sizeof(a[0]);
printf("before :");
printlist(a,len);
heapSort(a,len-1);
printf("after:");
printlist(a,len);
}
由于堆排序的数组索引从1开始,所以我已通过更改i,left,right ...的值将其手动更改为0。
但是问题仍然存在
以下是输出:之前:1 5 4 6 3 9 7之后:9 7 6 4 5 3 1
肯定有一些我没有注意到的错误,感谢您的帮助!
ps:谁能建议一个很酷的链接,它不能发现代码的错误或错误,这会很好。
问题在这里: