堆排序(数据结构)

本期讲解堆排序的实现


1. 堆排序

堆排序即利用堆的思想来进行排序,总共分为两个步骤:

1. 建堆

• 升序:建大堆
• 降序:建小堆
2. 利用堆删除思想来进行排序.

建堆和堆删除中都用到了向下调整,因此掌握了向下调整,就可以完成堆排序。

PS: 向下调整的代码实现已在上一篇博客最后(Heap.c) 分享

堆排序的两种实现

在此,我们提倡第二种堆排序的方法

1.

cs 复制代码
int a[]={2,5,7,4,1,6,9,8,3};

void HeapSort(int* a,int n)
{
	Heap heap;
	HeapInitArray(&heap, a, n);//建立了小堆

	//排序
	int i = 0;
	while (!HeapEmpty(&heap))
	{
		a[i] = HeapTop(&heap);
		printf("%d\n",a[i]);
		i++;//为了打印
		HeapPop(&heap);
	}

	HeapDestroy(&heap);
}

缺点:

1.空间复杂度为O(N)
2.需要去写堆的数据结构(子函数)太麻烦。

2.

cs 复制代码
//找降序,建小堆
void HeapSort(HeapDataType* a ,int n)
{
	//1.原数组建小堆,时间复杂度O(N)
	for (int i = (n - 1 - 1) / 2; i >= 0; i--)
	{
		AdjustDown(a,n,i);//参数:目的地,个数,开始调整的位置(parent)
	}
	//2.交换,继续使用向下调整, 时间复杂度O(N*logN)
	int end = n - 1;
	while (end > 0)
	{
		Swap(&a[0],&a[end]);
		AdjustDown(a,end,0);
		--end;
	}
}

堆排序的时间复杂度为o(N*logN)

这个博客如果对你有帮助,给博主一个免费的点赞就是最大的帮助**❤**

欢迎各位点赞,收藏和关注哦❤

如果有疑问或有不同见解,欢迎在评论区留言哦❤

后续我会一直分享双一流211西北大学软件(C,数据结构,C++,Linux,MySQL)的学习干货以及重要代码的分享

相关推荐
CoovallyAIHub15 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub16 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub16 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub16 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub17 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞17 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕18 小时前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub19 小时前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉