排序-----堆排序2

3 篇文章 0 订阅
2 篇文章 0 订阅
//-------堆排序---------//
void HeapAdjust(int *a, int i, int Length)
{
	int Child;
	int Temp;
	for (Temp = a[i]; 2 * i + 1 < Length; i = Child)
	{
		Child = 2 * i + 1;

		if (Child < Length - 1 && a[Child + 1] > a[Child])
		{
			++Child;
		}

		if (Temp < a[Child])
		{
			a[i] = a[Child];
		}
		else
		{
			break;
		}

		a[Child] = Temp;
	}
}

void HeapSort(int *a, int length)
{
	int i;
	int temp;

	for (i = length / 2 - 1; i >= 0; --i)
	{
		HeapAdjust(a, i, length);
	}

	for (i = length - 1; i > 0; --i)
	{
		temp = a[0];
		a[0] = a[i];
		a[i] = temp;

		HeapAdjust(a, 0, i);
	} 
}




int main()   
{   
    int *a;   
    int i, length;   
    int temp = 0;  
	
    printf("input :");   
    scanf("%d",&length);
	
    a = (int*) malloc((length+1) * sizeof(int));  
	
    printf("input %d Numble :", length);   

    for(i = 0; i < length; i++)   
    {   
        scanf(" %d", &a[i]);   
    }   
  
    HeapSort(a,length);  
	
    for(i = 0; i < length; i++)   
	{
        printf("%d ",a[i]);  
	}

    printf("\n");   
	return 1;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值