69,369
社区成员
发帖
与我相关
我的任务
分享
for (j=2*s+1;j< m;j=j*2+1)
for(i=L->length/2-1;i>=0;i--)
#include<stdio.h>
typedef struct
{
int r[12];
int length;
}List;
void HeapAdjust(List *L, int s, int m)
{
int temp,j;
temp=L->r[s];
for (j=2*s+1;j< m;j=j*2+1)
{
if(j+1<m && (L->r[j] > L->r[j+1]))
{
++j;
}
if(temp < L->r[j]) break;
L->r[s] = L->r[j];
s=j;
}
L->r[s] = temp;
}
void HeapSort(List *L)
{
int i;
for(i=L->length/2-1;i>=0;i--)
HeapAdjust(L,i,L->length);
for(i = L->length-1; i >= 0; i--)
{
int temp = L->r[0];
L->r[0] = L->r[i];
L->r[i] = temp;
HeapAdjust(L,0,i);
}
}
int main(int argc, const char * argv[]) {
List a;
List *L = &a;
L->length = 11;
L->r[0]=111;
L->r[1]=333;
L->r[2]=222;
L->r[3]=666;
L->r[4]=555;
L->r[5]=999;
L->r[6]=444;
L->r[7]=777;
L->r[8]=888;
L->r[9]=101;
L->r[10]=121;
HeapSort(L);
for(int i=0;i<11;i++)
{
printf("%d\n",L->r[i]);
}
return 0;
}