- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我很困惑,我以为你使用 Big O 表示最坏情况下的运行时间,而 Ω 表示最好情况?有人可以解释一下吗?
(lg n) 不是最好的情况吗?并且 (nlg n) 是最坏的情况?还是我误会了什么?
Show that the worst-case running time of Max-Heapify on a heap of size n is Ω(lg n). ( Hint: For a heap with n nodes, give node values that cause Max-Heapify to be called recursively at every node on a path from the root down to a leaf.)
编辑:不,这不是家庭作业。我在练习,这有一个答案,我很困惑。 http://www-scf.usc.edu/~csci303/cs303hw4solutions.pdf习题4(6.2 - 6)
编辑 2:所以我误解了与 Big O 和 Ω 无关的问题?
最佳答案
区分 case 和 bound 很重要。
最佳、平均和最差是分析算法时感兴趣的常见情况。
上限 (O, o) 和下限 (Omega, omega) 以及 Theta 是函数的常见边界。
当我们说“算法 X 的最坏情况时间复杂度为 O(n)”时,我们是说表示算法 X 性能的函数,当我们将输入限制为最坏情况输入时,从上方渐近地有界为一些线性函数。您可以谈论最坏情况输入的下限;或平均或最佳案例行为的上限或下限。
案例 != 绑定(bind)。也就是说,“最差的上限”和“最好的下限”是相当明智的度量标准……它们提供了算法性能的绝对界限。这并不意味着我们不能谈论其他指标。
编辑以回复您更新的问题:
该问题要求您证明 Omega(lg n) 是最坏情况行为的下界。换句话说,当这个算法对一类输入做尽可能多的工作时,它所做的工作量至少以渐进的速度增长到 (lg n)。因此,您的步骤如下: (1) 确定算法的最坏情况; (2) 在属于最坏情况的输入上找到算法运行时间的下界。
这是寻找线性搜索的方式的说明:
在线性搜索的最坏情况下,目标项不在列表中,必须检查列表中的所有项才能确定这一点。因此,该算法最坏情况复杂度的下限为 O(n)。
需要注意的重要事项:对于许多算法,大多数情况下的复杂性将受到一组通用函数的限制。和以下。应用 Theta 绑定(bind)是很常见的。因此,在任何情况下,很可能您对 Omega 的回答与对 O 的回答不同。
关于algorithm - 大 O 代表最坏情况运行时间,Ω 代表最好情况,但为什么有时 Ω 用于最坏情况?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15420848/
所以这只是一个好奇的问题。 如果我想退回单位,哪个更好? |> ignore 或者 () 应该还有其他方法。考虑到这些,我只想知道什么是最好的: 什么是性能最高的 生产环境的最佳实践是什么 什么是长期
我如何(最好)将方法调用返回的Option转换为Try(通过首选项,尽管Either或scalaz \/甚至是Validation都可以),包括在适当时指定Failure值? 例如,我有以下代码,虽然
我读了第一本关于 C# 的书,但对 LINQ 完全一无所知。请推荐对读者友好的 linq Material 。 谢谢 最佳答案 LINQ in Action已经有好几个人向我推荐了。 关于c# - 从
这个问题已经有答案了: How to create a template in HTML? (3 个回答) 已关闭 7 年前。 我正在寻找一种将一个 html 文件包含在另一个 html 文件中的最佳
我有一个在线注册,可以将数据保存到托管的 mssql 数据库中......基本上我想做的是在本地服务器上运行日常例行程序,就像 Insert into Home.tableA Select * fro
我有文本文件要加载到数据框中。加载后,这些值都在一列中,格式如下: 0 Alabama[edit] 1 Auburn (something somethign) 2 Florence (somethi
例如:我有一个带有外键的“历史”表,它可能根据字段值指向不同的表/实体。 表历史: create table history( id int PimaryKey AUTO_INC, e
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我有业务对象(DEVELOPERS WRITE)和一些 SPROCS(DBA WRITE) 谁能推荐一个好的对象映射器来处理这种设置。 我尝试了 codesmith 和 nhibernate,但遇到了
我应该测试 if 某事是否有效,还是只测试 try 来执行它并捕获异常? 是否有任何可靠的文档表明首选一种方法? 还有一种方式 pythonic? 例如,我应该: if len(my_list) >=
在 Java 中遍历字符串字符的一些方法是: 使用 StringTokenizer? 将 String 转换为 char[] 并对其进行迭代。 最简单/最好/最正确的迭代方式是什么? 最佳答案 我使用
我是一个真正的 Erlang 新手(1 周前开始),我正在尝试通过创建一个小而高效的聊天服务器来学习这种语言。 (当我说高效时,我的意思是我有 5 台服务器用于对数十万连接的客户端进行压力测试 - 一
这个问题已经有答案了: How to access the correct `this` inside a callback (15 个回答) 已关闭 5 年前。 我正在使用 NPM 包 prompt
到目前为止我已经做了一些测试(例如 RPC)接下来我来到多分页部分,到目前为止我读到的内容中有很多选项: MVP、布局、UIbind。 现在我真的不知道该选择哪个,哪个既简单又好。 我尝试清除我的根面
我们正在寻找我们能找到的最好的基于 jQuery 的用户界面库。它不一定是免费的。人们在使用什么? 我们使用过jQueryUI ,但发展似乎已经停滞。很长一段时间以来没有太多新东西。 jQuery T
我是 OpenCL 编程的初学者。我的 PC 装有 Windows 8.1,配备英特尔显卡和 AMD Radeon 7670。当我搜索下载 OpenCL SDK 和示例 helloworld 程序时,
我从人们那里得到的印象是...除非与 process.nextTick 一起使用,否则所有 JavaScript 函数都是同步的。什么时候使用它最好? 我想确保我不会在不需要它的地方过度使用它。在这一
我有一个单词列表,我想对其进行过滤,这样我就只有该单词列表中的名词(使用 Java)。为此,我正在寻找一种简单的方法来查询单词数据库的类型。 我的问题是有没有人知道一个免费、简单的单词查找 API,它
我想开发一个新的 iPhone 应用程序,我之前开发了一个应用程序,但被应用程序商店拒绝了,因为我使用的 StoryBoard 在之前的 iOS 4.3 中不起作用,所以我改用了 XIB。 现在最低版
我正在尝试制作注册表,我只想在其中注册特定域的电子邮件。例如我只想注册来自 companyX、companyY、companyZ 的电子邮件。 因此可接受的电子邮件将是:- myname@compan
我是一名优秀的程序员,十分优秀!