- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
大家下午好
我们说 hashtable有 O(1) 查找(假设我们有 key ),而 linked list查找下一个节点的时间复杂度为 O(1)(前提是我们有对当前节点的引用)。
然而,由于Big-O notation有效,它在表达(或区分)算法 x 的成本与算法 x + m 的成本方面不是很有用。
例如,即使我们将哈希表的查找和链表的查找标记为 O(1),这两个 O(1) 归结为非常不同的步骤数,
链表的查找固定在 x 步数。但是,哈希表的查找是可变的。哈希表的查找成本取决于哈希函数的成本,因此哈希表查找所需的步骤数为:x + m,
其中x是一个固定数
和m是一个未知的变量值
换句话说,即使我们将这两个操作都称为 O(1),哈希表查找的成本比链表查找的成本高数量级。
Big-O 表示法专门针对输入数据集合的大小。这确实有它的优点,但也有它的缺点,正如我们将所有非 n 变量折叠并归一化为 1 时所看到的那样。我们看不到里面的 m 变量(哈希函数)它了。
除了 Big-O 表示法之外,是否有另一种(已建立的)表示法我们可以用来表达固定成本 O(1),这意味着 x 操作和可变成本 O(1) 这意味着 x + m(m,哈希函数)操作次数?
最佳答案
literal O(1) which means exactly 1 operation
但事实并非如此。大 O-Notation 涉及与输入相关的复杂性的相对比较。如果算法确实采用恒定数量的步数,完全独立于输入的大小,那么确切的步数并不重要。
看看 O(n) 的(非正式)定义:
意思是:有某个k
这样对于每个 n
函数f
小于函数 g
.
在上面的例子中,哈希表查找和链接列表查找将是 f
, 和 g
将是 g(n) = 1
.对于每种情况,您都可以找到 k
那f(n) <= g(n) * k
.
现在,这个 k
不需要固定,它可能因平台、实现、特定硬件而异。唯一有趣的一点是它存在。这就是哈希表查找和链表节点查找都是 O(1) 的原因:无论输入如何,两者都具有恒定的复杂性。在评估算法时,这才是有趣的,而不是物理步骤。
特别是关于哈希表查找
是的,哈希函数确实需要可变数量的操作(取决于实现)。但是,它不会根据输入的大小进行可变数量的操作。 Big O-Nation 特别是关于输入数据集合的大小。哈希函数采用单个元素。对于算法的评估,某个函数是否需要 10、20、50 或 100 次操作并不重要,如果操作数不随着输入大小的增加而增加,则为 O(1)。在 big O-Notation 中无法区分这一点,因为这不是 big O-Notation 的目的。
关于language-agnostic - Big-O 符号的替代品?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10321079/
我一直在阅读Code Complete 2 .由于我不是以英语为母语的人,因此我需要一些时间才能理解某些陈述。我希望你描述作者在他的书中所做的这两个陈述之间的区别: You should progra
我将 TYPO3 安装从 8.6 升级到 9.5。在内容语言设置为“所有语言”的页面上,这些元素不会显示在前端。 似乎在 ContentObjectRenderer->getQueryConstrai
我和一个学生正在建立一个新的口译员家庭,我们希望以现有口译员为基准。我们很乐意下载包含 Computer Language Benchmarks Game 中使用的所有源代码的 tarball 或 z
因此,我正在尝试创建一个双语网站,只需单击一下即可将其从英语切换为葡萄牙语,反之亦然。 我收到此错误:Use of undefined constant language - assumed 'lan
我正在阅读一个比较不同编程语言的演示文稿。衡量的特征之一是“语言表现”。什么意思? 最佳答案 真正的答案:它没有任何意义,或者该演示文稿的作者当时在想什么。 也许它的意思是“执行相对于其他语言具有相同
Go talk 2009 pdf 有评论解释了他们为什么想出 go 语言: No new major systems language in a decade. 系统语言是什么意思? 它是一种应该通过
我现在正在使用 Squeak4.1 学习 SmallTalk。我使用 Squeak by Example 作为教程,在这里我反驳了一个 delema,“Morphic 是由...开发的,用于自编程语言
谁能告诉我如何编译和运行在 ZOMBIE 上编写的程序?例如,如果我编写了以下源代码线以将“hello world”打印到屏幕上,我该如何制作一个 .exe 文件。谢谢! HelloWorld is
我在看帖子Why Language is Important (Why I prefer C#)来自“Dot Net Thoughts”,文章的第一段以以下声明结尾: ...every languag
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 7年前关闭。 Improve t
我正在尝试使用 qTranslate X 制作一个基本的语言切换器,例如: FR | EN 有一个函数可以实现这一点:qtranxf_generateLanguageSelectCode('text'
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我正在研究浏览器指纹。在应用程序的 webview 中运行的 js 将通过获取 navigator.language.substr(0,2) == navigator.languages[0].sub
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
"Page description language"、"markup language"、"Page description markup language"有什么区别和关系? 根据他们的 wiki
我正在为 IntelliJ 创建一个自定义语言插件。 我希望新语言的文件可以包含其他语言的文本片段。 我想支持的特定语言是 HTML、JS、CSS 和 SQL。 我还想支持其他自定义语言(即我要为其定
我正在用 mysql 创建一个图书数据库。一本书可以有不同的语言。并且将会有数千本书。 (而且我远不是这个领域的专家,之前只创建过小型和简单的数据库) 1) 只创建一个包含语言列的表并为其创建索引是否
我的网站使用用户可切换的三种不同语言。语言切换由 JavaScript (AngularJS) 在客户端完成。 我在我的网站上使用 reCAPTCHA 2,当用户切换网站语言时需要更改 reCAPTC
我在 Core Image Kernel Language 中有以下函数,我需要在 Metal Shading Language 中等效的东西,但是我对 destCoord 、 unpremultip
“不存在‘编译语言’或‘解释语言’之类的东西。语言实现者选择编写编译器、解释器还是两者之间的任何东西都是实现细节,与语言无关。” 上述说法是否属实? 最佳答案 是的,在最严格的解释中它是正确的。您可以
我是一名优秀的程序员,十分优秀!