堆排序

算法思想:建立一个最大堆(最小堆),最大堆满足一个性质,即所有的父结点都要比它的左右结点大,故可以每次将根结点抽取出来放在最后面,每次都抽取剩余部分的最大值,那最终得到的序列就是有序的

建立最大堆的方法:从最底层的父结点开始,从下往上,不断的把子树调整成最大堆,最后根结点就是最大元素,然后跟最后面的元素交换位置,交换完再重新进行调整

#include <iostream>
#include <algorithm>
#include <cstdio>

using namespace std;
const int N = 1e5;
int a[N];

void HeapAdjust(int i, int size)
{
	int left = 2 * i;           //左孩子节点
	int right = 2 * i + 1;      //右孩子节点
	int mx = i;                 //暂存最大元素下标
	if(left <= size && a[left] > a[mx])
		mx = left;
	if(right <= size && a[right] > a[mx])
		mx = right;
	if(mx != i)                 //当前父结点不是最大的
	{
		swap(a[i], a[mx]);
		HeapAdjust(mx, size);   //递归处理子树
	}
}
void BuildHeap(int size)
{
	for(int i = size / 2; i >= 1; i--) //非叶结点最大下标为size/2
		HeapAdjust(i, size);
}
void HeapSort(int size)
{
	BuildHeap(size);            //建立初始最大堆
	for(int i = size; i >= 2; i--)
	{
		swap(a[1], a[i]);       //把最大元素放在最后面
		size--;                 //不包括最大元素
		HeapAdjust(1, size);    //重新调整
	}
}

int main()
{
	int n;
	cin >> n;
	for(int i = 1; i <= n; i++)
		scanf("%d", &a[i]);
	HeapSort(n);
	for(int i = 1; i <= n; i++)
		printf("%d ", a[i]);
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值