堆排序算法(选择排序改进)

本文介绍了堆排序算法的核心思想和步骤,首先解释了堆的性质,然后详细说明了如何建立大顶堆或小顶堆,并通过调整节点位置来完成排序。堆排序的过程包括构建堆和交换与调整两个阶段,最终实现数据的排序。文章还提到了堆排序的时间复杂度为O(nlogn)。
摘要由CSDN通过智能技术生成

首先要理解堆的含义:要么所有节点都不大于其子孩子节点数据,要么都不小于其子孩子节点数据

堆排序的核心思想:就是要满足所有节点都满足上面两点,如何完成,看下面

堆排序的步骤:

1.首先要建成一个大顶堆或者小顶堆,在建的过程中其实就是调整节点的位置,首先要从最后最后一个节点的母亲节点开始,按照堆的含义调整。为什么不是最后一个或者其他?因为要保证完整性和不必要性,所以只需从最后一个的母亲节点开始即可(下面的堆默认存在顺序结构,从索引0开始的,所以有些二叉树的特性请查阅二叉树),直至索引节点为0的节点。调整完成后即成为一个堆,但是这里的数据并没有排序好,所以下一部调整顺序。

2.从最后一个数据开始,与第一个数据进行交换,然后按照堆的含义调整第一个数据。为什么先选择最后一个数据?因为默认情况下,最后一个或者是较大或者是较小,可以满足调整要求。这时就考虑当前所有数据减去最后一个,因为这个已是最大或者是最小,不必再考虑.。直至调整没有任何数据,此时已完成排序。

具体图例不再标识,有此爱好可以参考其他书籍或者网上的介绍,下面看堆排序代码:

int HeapSort(MergeType* L)
{
	int i = 0;
	if (!L->elem)
	{
		return -1;
	}

	//创建堆
	for (int i = L->len/2-1; i >= 0; i--)
	{
		HeapAdjust(L, i, L->len-1);
	}

	//堆排序
	for (i = L->len-1; i >= 0; i-- )
	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值