C语言实现堆排序的简单实例
本文通过一个C语言实现堆排序的简单实例,帮助大家抛开复杂的概念,更好的理解堆排序。
实例代码如下:
voidFindMaxInHeap(intarr[],constintsize){
for(intj=size-1;j>0;--j){
intparent=j/2;
intchild=j;
if(j<size-1&&arr[j]<arr[j+1]){
++child;
}
if(arr[child]>arr[parent]){
inttmp=arr[child];
arr[child]=arr[parent];
arr[parent]=tmp;
}
}
}
voidHeapSort(intarr[],constintsize){
for(intj=size;j>0;--j){
FindMaxInHeap(arr,j);
inttmp=arr[0];
arr[0]=arr[j-1];
arr[j-1]=tmp;
}
}
intmain()
{
intarr[]={2,5,3,12,6,21,8,1};
intn=sizeof(arr)/sizeof(arr[0]);
HeapSort(arr,n);
for(intj=0;j<n;++j){
printf("%3d",arr[j]);
}
printf("\n");
return0;
}热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短