2022/1/17总结

堆的学习:

定义:堆是一个完全二叉树,每一个结点的值都不小于或者不大于其左右子树结点的值。如果父亲结点的值大于等于孩子结点的值,这样的堆被称为大顶堆,此时每个结点的值都是以它为根结点的子树的最大值;相反,如果父亲结点的值小于等于孩子结点的值,这样的堆则称为小顶堆,此时每个结点的值都是以它为根结点的子树的最小值。

具体通过图片来看看

 进行若干次操作后,最终得到

 

根据这个定义建堆:

代码实现

const int N = 100;//根据题目,具体情况具体分析来决定N的大小
int heap[N], n =10;//heap是堆,n为元素个数
void down(int low, int high)
{
	int i = low, k = i * 2;//i为想要调整的结点,k为左孩子
	while(k <= high)//孩子结点存在
	{
		if(k + 1 <= high && heap[k + 1] > heap[k])//如果右孩子存在,且右孩子值大于左孩子
		{
			k = k + 1;//储存下标
		}	
		if(heap[k] > heap[i])
		{
			swap(heap[k], heap[i]);//交换最大权值的孩子与想要调整的结点
			i = k;
			k = i * 2;
		}else break;//孩子的权值都比要调整的结点小,结束循环
	}
}
void createheap()//建堆
{
    for(int i = n / 2; i >= 1; i--)
    {
        down(i,n);
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值