- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这个问题在这里已经有了答案:
10年前关闭。
Possible Duplicate:
Plain English explanation of Big O
最佳答案
取决于您想跳入的位置,this可能是一个很好的脚趾头。 wiki页面质量也很高,而且更深入一些。 This是一本不错的高年级本科或研究生入门教材,会进入linear speedup theorem ,这是计算机科学家在讨论算法运行时完全使用大 O 符号的一个重要原因。简而言之,它说你总是可以通过在硬件上投入大量资金来获得速度提升的线性因素。
Big-O 符号的优点在于它允许我们丢弃成本公式末端的“松散变化”。这是由隐含假设证明的,即我们只关心输入的大小达到无穷大的极限情况,并且我们的成本的最大项支配其他项。
执行复杂性分析要求您首先为您的输入选择一个度量,然后决定您希望测量其消耗的资源,然后计算算法在给定大小的输入上运行时所占用的数量。按照惯例,输入大小被命名为 N
.典型的资源是执行的“步骤”数量或存储在所有容器中的项目,但这些只是(流行的)示例。相比之下,基于比较的排序算法通常只关注交换的次数。
输入的大小通常不是算法运行时间或需要多少空间的唯一决定因素。例如,插入排序的运行时间在以已排序和反向排序顺序呈现的等长输入之间存在显着差异。这就是我们谈论最坏情况与平均情况复杂度(或最佳情况等)的原因。通过询问例如“可能发生的最糟糕的事情是什么?”,我们可以决定如何遍历源并计算用法。
平均情况复杂度很棘手,因为它们需要了解可能输入的分布。最坏情况的复杂性与输入分布无关,并为我们提供了硬上限,这在实践中通常是我们所需要的。
例如,如果算法如 Bubble Sort将一组项目作为输入,典型的度量是数组的长度。假设我们希望计算它在最坏情况下进行的掉期次数。这是它的伪代码,取自维基百科:
procedure bubbleSort( A : list of sortable items )
repeat
swapped = false
for i = 1 to length(A) - 1 inclusive do:
if A[i-1] > A[i] then
swap( A[i-1], A[i] )
swapped = true
end if
end for
until not swapped
end procedure
for
循环,一个嵌套在另一个内部的内部循环。内循环从
1
开始计数至
length(A) - 1
,并使最大值
N - 1
当数组的最大元素在前面时正好交换。只要最后一次发生任何交换,外循环就会重复这个过程。假设在最坏的情况下之前通过,之前最大的未排序元素将位于列表的末尾,有效地缩小了我们可以将下一个最大的未排序元素移动一个的距离。所以,每一次连续的传递都会减少一次交换,我们最终得到
N + (N-1) + (N-2) + ... + 2 + 1 = N * (N + 1) / 2 = 1/2 * N^2 + N/2
O(1/2 * N^2 + N/2) = O(1/2 * N^2) = O(N^2)
N/2
) 项,因为它将以二次项为主,如
N -> inf
.然后我们放下
1/2
主要常数因子,因为它本质上是一个硬件细节。请注意,这是人类的动机:big-O' 的巧妙之处在于它的定义为容纳我们的动机提供了一个严格的框架。事实证明,该框架说我们放弃了主要的常数因素。
关于algorithm - 算法空间复杂度教程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7306300/
我正在做一个关于代码学院的教程,我在这里收到一个错误,说“看起来你的函数没有返回‘唉,你没有资格获得信用卡。资本主义就是这样残酷。’”当收入参数为 75 时。”但是该字符串在控制台中返回(由于某种原因
我正在阅读 Go 的官方教程,但很难理解 Channel 和 Buffered Channels 之间的区别。教程的链接是 https://tour.golang.org/concurrency/2和
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 9年前关闭。 Improve this que
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
作为 iOS 新手,有大量书籍可以满足学习基础知识的需求。现在,我想转向一些高级阅读,例如 OAuth 和 SQLite 以及动态 API 派生的 TableView 等。您可以推荐任何资源吗? 最佳
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 8 年前。
前言 很多同学都知道,我们常见的CTF赛事除了解题赛之外,还有一种赛制叫AWD赛制。在这种赛制下,我们战队会拿到一个或多个服务器。服务器的连接方式通常是SSH链接,并且可能一个战队可能会同时有
Memcached是一个自由开源的,高性能,分布式内存键值对缓存系统 Memcached 是一种基于内存的key-value存储,用来存储小块的任意数据(字符串、对象),这些数据可以是数据库调用、A
Perl 又名实用报表提取语言, 是 Practical Extraction and Report Language 的缩写 Perl 是由 拉里·沃尔(Larry Wall)于19
WSDL 是 Web Services Description Language 的缩写,翻译成中文就是网络服务描述语言 WSDL 是一门基于 XML 的语言,用于描述 Web Services 以
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
我正在寻找解释在 WPF 中创建自定义用户控件的教程。 我想要一个控件,它结合了一个文本 block 、一个文本框和一个启动通用文件打开对话框的按钮。我已经完成了布局,一切都连接好了。它有效,但它是三
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我接近 fourth page of the Django tutorial 的开始看着vote查看,最后是这样的: # Always return an HttpResponseRedirect a
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
是否有任何好的 Qt QSS 教程,或者在某个地方我可以看到样式小部件的示例?如果某处可用,我想要一些完整的引用。除了有关如何设置按钮或某些选项卡样式的小教程外,我找不到任何其他内容。 最佳答案 Qt
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是一名优秀的程序员,十分优秀!