数据结构:关于大根堆的插入问题,如图所示

如图所示题目该咋做啊,能不能参考王道c语言堆的算法给出答案,求教... 如图所示题目该咋做啊,能不能参考王道c语言堆的算法给出答案,求教 展开
 我来答
xgn911
2022-11-01 · TA获得超过1366个赞
知道小有建树答主
回答量:1493
采纳率:96%
帮助的人:705万
展开全部

假设大根堆数组元素为a[1],a[2],...,a[n],下标从1开始,a[0]可用来临时保存数据

尾部增加的元素一定是叶子节点,这里为a[n+1],假设其下标为k

则其父节点下标为k/2,大根堆中父节点的值一定要大于等于子节点

所以将a[k]向上调整,不断与其父节点比较,大于父节点就要将父节点向下复制

直到a[k]小于等于其父节点停止,然后将a[n+1]的值插入到当前的a[k]位置即可

参考代码如下:

可见插入过程与图2中的HeapAdjust()方向正好相反,一个向上调整,一个向下调整

源码为:

// 将大根堆中的叶子节点a[k]向上调整

void MaxHeapFixup(int a[], int k) {

    a[0] = a[k]; // a[0]临时保存a[k]的值

    int i; // a[i]为a[k]的父节点

    for (i = k/2; i >= 1; i = i/2) {

        if (a[i] >= a[k]) // 满足父节点不小于其子节点,即找到插入位置

            break;

        else {

            a[k] = a[i]; // 否则将更小的父节点的值向下复制给其子节点

            k = i;

        }

    }

    a[k] = a[0]; // 将叶子节点插入到当前满足大根堆条件的位置

}

// 在大根堆中插入新元素num,默认插入到最后一个位置

void MaxHeapAddNum(int a[], int n, int num) {

    a[n + 1] = num;

    MaxHeapFixup(a, n + 1);

}

Sievers分析仪
2025-05-06 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准... 点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式