- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用堆栈的数组实现,如果堆栈已满而不是抛出错误,我会将数组大小加倍,复制元素,更改堆栈引用并将新元素添加到堆栈中。 (我正在跟着一本书自学这些东西)。
我不完全明白为什么要加倍,为什么不增加一个固定的数量,为什么不增加3倍。
我认为它与时间复杂度有关吗?
一个解释将不胜感激!
最佳答案
从理论上讲,您确实到达了不同的时间复杂度。如果增加一个常量大小,则将重新分配的数量(因此是 O(n) 个副本)除以一个常量,但您仍然会获得 O(n) 的追加时间复杂度。如果将它们加倍,则追加的时间复杂度更高(装甲化 O(1) IIRC),并且由于您最多消耗两倍所需的内存,因此仍然获得相同的空间复杂度。
在实践中,它不那么严重,但仍然可行。副本很昂贵,而一点内存通常不会受到伤害。这是一种权衡,但您必须非常低内存才能选择另一种策略。通常,您事先不知道(或由于 API 限制而无法让堆栈知道)您实际需要多少空间。例如,如果你从一个元素开始构建一个 1024 个元素的堆栈,你会从 1024/K 开始(我可能会偏离一个)10 次重新分配——假设 K=3,那将是大约 34 倍许多重新分配,只是为了节省一点内存。
这同样适用于任何其他因素。 2 很好,因为你永远不会得到非整数大小,而且它仍然很小,将浪费的空间限制在 50%。其他因素可能会更好地为特定用例提供服务,但通常 ROI 太小,无法证明重新实现和优化某些库中已有的内容是合理的。
关于arrays - 为什么要双倍堆叠容量而不是仅仅增加固定数量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10419250/
我有三个 double 组列表。我想将数组1复制到数组2并将其放入第三个数组中。 // ArrayList 1 [0.0, 1.0, 0.0, 1.0] // ArrayList 2 // Rando
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在编写一个带有变量 long balance 的银行程序将美分存入账户。当用户输入金额时,我有一种方法可以将美元转换为美分: public static long convertFromUsd (
如何 DRY(不要重复自己)RSpec 中的 double?例如: let(:s1) {instance_double(Class1, :att
我是 Java 新手,我想知道为什么当你有双 10/4 时却得到 2? double 是否总是必须有小数才能得到正确的答案?谢谢。 public class Super { public st
我正在用 Python 为 Fortran 库编写前端。 Python 模块应该可以在 32 位和 64 位机器上运行;适用于 Windows、Linux 和 Mac。 我想了解一些数据类型的字节宽度
我有两个ajax json。一个用于聊天用户列表列,另一个用于每个用户的消息历史记录。当单击 $('.member_list ul li') 元素时...第二个 ajax 将 li 的值作为 json
从 GHCi 中的 .hs 文件加载 a = 2+2.0 并执行 :t a 显示 a::Double。 另一方面,在 GHCi 中执行 let b = 2+2.0 和 :t b 会显示 b::Frac
我是一名优秀的程序员,十分优秀!