大根堆升序排序

该博客介绍了如何使用大根堆实现升序排序。通过定义堆结构`Myheap`,实现了`IncreaseKey`、`Insert`和`PopMaxHeap`等函数,用于插入元素、调整堆以及获取并删除最大值。最后,`main`函数展示了如何利用这些函数对输入的整数进行堆排序,并打印排序后的结果。
摘要由CSDN通过智能技术生成
#define _CRT_SECURE_NO_WARNINGS
#include<stdlib.h>
#include<stdio.h>
typedef struct 
{
	int *pnData;//指向堆里结点数据的指针
	int nSize;//当前堆中结点的个数,
}Myheap;//堆
int IncreaseKey(Myheap*pheap, int nPos)	//进行比较调整新插入结点的位置
{
	while (nPos > 1)//循环和他的双亲结点比较
	{
		int nMax = pheap->pnData[nPos];//临时变量,存取新插入结点的值
		int nParent = nPos / 2;
		if (nMax > pheap->pnData[nParent])//向上渗透
		{
			pheap->pnData[nPos] = pheap->pnData[nParent];
			pheap->pnData[nParent] = nMax;
			nPos = nParent;//向上移动
		}
		else
		{
			break;
		}

	}
	return 1;
}
int Insert(Myheap *pheap,int nData)//插入新节点
{
	++pheap->nSize;//堆的结点数会+1
	//从1开始插入
	pheap->pnData[pheap->nSize] = nData;
	IncreaseKey(pheap, pheap->nSize);//将刚刚插入的数和位置与堆进行比较,从底层向上渗透
	return 1;

}
int PopMaxHeap(Myheap *pheap)//得到堆中根结点的关键字,并弹出堆中最大的数  
{
	int nMax = pheap->pnData[1];//得到堆最大值
	int nPos = 1;
	int nChild = nPos * 2;//得到左孩子结点
	while (nChild
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值