首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >插入堆最多一个交换?

插入堆最多一个交换?
EN

Stack Overflow用户
提问于 2013-10-02 06:53:48
回答 1查看 463关注 0票数 0

Udi Manber的著名著作“算法导论”中有这样一个问题,即:

算法*Insert_To_Heap*可能会在堆上多次交换。修改算法,以便最多执行一个交换。O(log )比较仍然被允许。

我想不出任何这样的算法,我甚至认为这是不可能的(就像您在最大堆中插入最大元素一样,它似乎无法工作)。有些答案甚至存在,说明这是impossible.But认为这个问题是一个好的来源,我再问一次,如果你能给一些好的想法,并找出作者想问的是什么?

EN

回答 1

Stack Overflow用户

发布于 2013-10-28 09:18:12

我认为,如果我们使用二叉树来实现堆,并且每个子节点都包含指向其父节点的指针,那么我们可以在一个插入操作和O(logN)比较操作中完成logN。然而,这可能会生成一个只有一个子节点,这将导致一个更高的树。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19131438

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档