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

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

假设大根堆数组元素为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);

}

迈杰
2024-11-30 广告
迈杰转化医学研究(苏州)有限公司于2013年成立,其前身为凯杰(苏州)转化医学研究有限公司。基于基因组学、蛋白组学、细胞组学及病理组学等综合性转化医学平台,丰富的伴随诊断开发经验,高质量的管理体系以及高素质的研发管理团队,迈杰转化医学为全球... 点击进入详情页
本回答由迈杰提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式