前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >数据结构之堆排序

数据结构之堆排序

作者头像
egoist祈
发布2025-01-23 13:37:29
发布2025-01-23 13:37:29
5000
代码可运行
举报
文章被收录于专栏:egoistegoist
运行总次数:0
代码可运行

堆排序

版本一

  1. 基于已有数组建堆
  2. 取堆顶元素并删除堆顶元素重新建大根堆,完成排序版本。
图文理解

版本二

前提:必须提供有现成的数据结构堆

数组建堆,首尾交换,交换后的堆尾数据从堆中删掉,将堆顶数据向下调整选出次大的数据。

向下调整建堆
  1. 先把每棵子树通过向下调整算法建成大根堆;
  2. 整体建成大根堆结构。
代码语言:javascript
代码运行次数:0
复制
	for (int i = (n - 1 - 1) / 2;i >= 0;i--)
	{
		AdjustDown(arr, i, n);
	}
代码语言:javascript
代码运行次数:0
复制
void AdjustDown(HPDataType* arr, int parent, int n)
{
	int child = parent * 2 + 1;
	while (child < n)
	{
		if (child + 1 < n && arr[child] < arr[child + 1])
		{
			child++;
		}
		//>建小堆
		//<建大堆
		if (arr[parent] < arr[child])
		{
			Swap(&arr[parent], &arr[child]);
			parent = child;
			child = parent * 2 + 1;
		}
		else {
			break;
		}
	}
}
向上调整建堆
  1. 堆顶元素开始建堆;
  2. 通过将每一个结点进行建大根堆,最后整体就是大根堆结构。

通过顺序结构二叉树文章可知,向下调整算法的时间复杂度优于向上调整算法,因此更推荐用向下调整建堆

代码语言:javascript
代码运行次数:0
复制
	for (int i = 0;i < n;i++)
	{
		AdjustUp(arr, i);
	}
代码语言:javascript
代码运行次数:0
复制
//向上调整
void AdjustUp(HPDataType* arr, int child)
{
	int parent = (child - 1) / 2;
	while (child > 0)
	{
		//>:大堆
		//<:小堆
		if (arr[child] > arr[parent])
		{
			//交换
			Swap(&arr[child], &arr[parent]);
			child = parent;
			parent = (child - 1) / 2;
		}
		else {
			break;
		}
	}
}

排升/降序

排成升序结构,建大根堆; 排成降序结构,建小根堆。

升序
代码语言:javascript
代码运行次数:0
复制
	int end = n - 1;
	while (end > 0)
	{
		Swap(&arr[0], &arr[end]);
		AdjustDown(arr, 0, end);
		end--;
	}

注:当前是大根堆结构

  1. 将堆顶数据与末端数据交换;
  2. 重新建成大根堆结构,保证下次取到的堆顶数据依然是最大值;
  3. 最后数据将会排成升序结构。

那么,降序结构原理也类似上图所示。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-01-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 堆排序
    • 版本一
      • 图文理解
    • 版本二
      • 向下调整建堆
      • 向上调整建堆
    • 排升/降序
      • 升序
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档