#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
大根堆升序排序
最新推荐文章于 2024-10-04 13:32:19 发布
该博客介绍了如何使用大根堆实现升序排序。通过定义堆结构`Myheap`,实现了`IncreaseKey`、`Insert`和`PopMaxHeap`等函数,用于插入元素、调整堆以及获取并删除最大值。最后,`main`函数展示了如何利用这些函数对输入的整数进行堆排序,并打印排序后的结果。
摘要由CSDN通过智能技术生成