- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我在大学学习数据结构类(class)时,我学到了以下公理:
在最坏的情况下,向堆中插入一个新数字需要 O(logn)(取决于它作为叶子插入时在树中到达的高度)
构建n 个节点的堆,使用n 个插入,从一个空堆开始,总计为O(n) 时间,使用摊销分析
在最坏的情况下,移除最小值需要 O(logn) 时间(取决于新的顶部节点在与最后一个叶子交换后到达的最低点)
将所有最小值一一移除,直到堆为空,耗时O(nlogn)时间复杂度
提示“堆排序”算法的步骤是:
我的问题是:为什么摊销分析技巧在清空堆时不起作用,导致堆排序算法花费O(nlogn)时间而不是< strong>O(n) 次?
当堆存储在数组中(而不是带有指针的动态树节点)时,我们可以自底向上构建堆,即从叶子开始向上到根,然后使用摊销分析我们可以得到O(n) 的总时间复杂度,而我们不能清空堆最小值的自下而上。
最佳答案
假设您只能通过比较两个对象来了解它们的相对排名,那么就无法在时间 O(n) 内从二叉堆中取出所有元素。如果你能做到这一点,那么你可以通过在时间 O(n) 内构建堆然后在时间 O(n) 内将所有内容出队来在时间 O(n) 内对列表进行排序。但是,排序下限表示比较排序为了正确,平均运行时间必须为 Ω(n log n)。换句话说,您不能太快地从堆中出列,否则您会打破排序障碍。
还有一个问题是为什么从二叉堆中取出 n 个元素需要时间 O(n log n) 而不是更快。展示起来有点棘手,但这是基本思想。考虑您在堆上进行的出列的前半部分。查看实际出列的值并考虑它们在堆中的位置。除了最下面一行的那些,其他所有出队的东西都必须一次一个交换地渗透到堆的顶部才能被删除。您可以证明堆中有足够的元素来保证仅此一项就需要时间 Ω(n log n),因为这些节点中大约有一半将位于树的深处。这解释了为什么摊销论点不起作用——你不断地将深层节点拉到堆上,所以节点必须移动的总距离很大。将此与 heapify 操作进行比较,其中大多数节点移动的距离非常短。
关于sorting - 堆排序时间复杂度深入理解,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32123051/
最近做一个项目,由于是在别人框架里开发app,导致了很多限制,其中一个就是不能直接引用webservice 。 我们都知道,调用webserivice 最简单的方法就是在 "引用"
这是SDL2代码的一部分 SDL主函数 int main(int argc,char *argv[]) { ... ... bool quit=false; S
c 中的函数: PHPAPI char *php_pcre_replace(char *regex, int regex_len, ch
我有以下映射: public class SecurityMap : ClassMap { public SecurityMap() {
我在vue-lic3中使用了SCSS,但是有一个奇怪的错误,使用/ deep /会报告错误,我不想看到它。 代码运行环境 vue-cli3 + vant + scss 的CSS /deep/ .van
我在深入阅读 C# 时遇到了这个我能理解的内容: 当它被限制为引用类型时,执行的比较类型完全取决于类型参数被限制为什么。 但是不能理解这个: 如果进一步限制派生自重载 == 和 != 运算符的特定类型
Closed. This question is opinion-based。它当前不接受答案。 想改善这个问题吗?更新问题,以便editing this post用事实和引用来回答。 3年前关闭。
有人可以详细介绍关于自赋值的运算符重载中的 *this 和 const 例如: Class& Class::operator=(const Class& other) { a = other.
在向树中插入新节点时,如何填充闭包表的深度/长度列? ancestor 和 descendant 中的值是来自另一个表的 ID,表示要以树结构排列的页面。 关闭表: ancestor desce
现在我正在阅读“深入了解 C#”。缺少的一件事是完成一章后我可以解决的一系列问题。那会帮助我理解我刚刚学到的概念。 哪里可以找到适合 C#3.0 的问题集? 谢谢 最佳答案 你可以试试LINQ 101
TypeScript 给 JavaScript 扩展了类型的语法,我们可以给变量加上类型,在编译期间会做类型检查,配合编辑器还能做更准确的智能提示。此外,TypeScript 还支持了高级类型用
是否有一个单行代码来获取生成器并生成该生成器中的所有元素?例如: def Yearly(year): yield YEARLY_HEADER for month in range(1, 13)
所以我阅读了一些与“什么是方法组”相关的 StackOverflow 问题以及其他互联网文章,它们在底线都说了同样的话——方法组是“一组重载方法” ". 但是,在阅读 Jon Skeet 的“C# 深
有什么方法可以从子组件中获取子组件吗? 想象一下以下组件树: 应用程序 问题 问题选项(包含复选框) 问题选项(包含复选框) 问题选项(包含复选框) 我想从 App 访问问题选项以选中所有复选框。 参
class_eval 和 instance_eval 在定义方法等情况下是完全可以预测的。我也理解类的实例和类的单例(又名特征类)之间的区别。 但是 我无法弄清楚以下唯一的事情:比方说,出于某些策略目
我想出了如何将符号 rwx 部分读取/转换为 421 个八进制部分,这非常简单。但是当涉及到特殊字符时,我感到非常困惑。我们知道 -r-xr---wx 转换为 0543,但 -r-sr---wt 或
我怀疑我系统的 Java 版本有问题。某些应用程序出现段错误或内存不足或存在链接错误。如果我从源代码安装了 JDK,我会做类似“make test”的事情,看看哪些测试失败了。但是,看起来从源代码构建
如何克隆一个 repo(使用 libgit2 ) 我想做什么git clone确实,但有 libgit2 .我可能要问的是什么 git clone确实很深入。 这是我目前正在做的: 初始化一个repo
00、头痛的JS闭包、词法作用域? 被JavaScript的闭包、上下文、嵌套函数、this搞得很头痛,这语言设计的,感觉比较混乱,先勉强理解总结一下😂😂😂.
我开始玩 lubridate R 中的包。我注意到 now(tzone="EST")计算为: [1] "2015-08-25 13:01:08 EST" 而 now(tzone="PST")导致警告:
我是一名优秀的程序员,十分优秀!