堆排序,数组的索引从1开始而不是0

问题描述 投票:0回答:1
#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:谁能建议一个很酷的链接,它不能发现代码的错误或错误,这会很好。

c heap heapsort
1个回答
1
投票

问题在这里:

© www.soinside.com 2019 - 2024. All rights reserved.