- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
查看哈希表的基本结构。我们知道它会调整 WRT 负载因子或其他一些确定性参数的大小。我知道如果在插入中达到调整大小限制,我们需要创建一个更大的哈希表并在那里插入所有内容。这是我没有得到的东西。
让我们考虑一个哈希表,其中每个桶都包含一个 AVL 平衡的 BST。如果我的哈希函数为每个键返回相同的索引,那么我会将所有内容存储在同一个 AVL 树中。我知道这个散列函数将是一个非常糟糕的函数并且不会被使用,但我在这里做的是最坏的情况。因此,经过一段时间后,我们可以说已达到调整大小因子。所以为了调整大小,我创建了一个新的哈希表,并尝试在我之前的表中插入每个旧元素。由于哈希函数将所有内容映射回一个 AVL 树,因此我需要将所有 N 个元素插入同一个 AVL。 AVL 树上的 N 次插入是 N logN。那么为什么哈希表插入的最坏情况被认为是 O(N) 呢?
下面是将 N 个元素加入 Avl 三的证明是 N logN:
Running time of adding N elements into an empty AVL tree
最佳答案
总之 :这取决于存储桶的实现方式。使用链表,在特定条件下可以在 O(n) 中完成。对于将 AVL 树作为桶的实现,这确实会导致 O(n log n)。为了计算时间复杂度,应该知道桶的实现。
通常,bucket 不是用 AVL 树或一般的树实现的,而是用链表实现的。如果有引用last
列表的条目,追加可以在 O(1) 中完成。否则我们仍然可以通过添加链表来达到 O(1)(在这种情况下,桶以相反的插入顺序存储数据)。
使用链表的想法是,使用合理散列函数的字典应该导致很少的冲突。通常一个桶有零个或一个元素,有时有两个或三个,但不多。在这种情况下,简单的数据结构会更快,因为更简单的数据结构通常每次迭代需要更少的周期。
一些哈希表使用开放寻址,其中桶不是分离的数据结构,但如果桶已经被占用,则使用下一个空闲桶。在这种情况下,搜索将因此迭代使用过的存储桶,直到找到匹配的条目,或者到达空存储桶。
Wikipedia article on Hash tables讨论如何实现存储桶。
关于time-complexity - 为什么哈希表插入时间复杂度最坏的情况不是 N log N,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56924680/
我有一个使用 c++ 的大型代码库标题和许多std::complex对象。但现在我还想使用其他几个使用 fftw 的库( spinsfast 和 ) .不幸的是,混合这两种类型的复合体似乎与 gc
我是 Maxima 的新手,在文档中找不到如何对复数进行正式计算。当我使用未指定的变量时,Maxima 似乎假设它们是真实的: 例如,共轭(x)返回 x。 有没有办法解决这个问题? 提前致谢。 最佳答
我是学习大O表示法的新手,并想到了这个问题。复杂度 O(a * b) 的名称是什么?是线性复杂度吗?多项式?或者是其他东西。实现代码如下。 function twoInputsMult(a, b) {
我是学习大O表示法的新手,并想到了这个问题。复杂度 O(a * b) 的名称是什么?是线性复杂度吗?多项式?或者是其他东西。实现代码如下。 function twoInputsMult(a, b) {
这是我的 Complex 类,我重载了“+” class Complex(object): def __init__(self, real, imag): self.__ima
我正在使用 R5RS 标准的 Scheme 实现。 现在假设您必须找出一个元素 '(2 3 4) 是否在列表 '(1 2 3 4) 中。 至于示例,更严格地说,您希望: 1. (is-in? '(2
注意事项: 我正在使用 Apple LLVM 版本 6.0 (clang-600.0.56)(基于 LLVM 3.5svn)在 OSX 上编译 具体来说,我正在尝试从 LibIIR 编译一个整体源,这
这段fortran代码最初是用Fortran 77格式编写的(我稍后会展示它)。拿到后,我通过转换工具将其转换为f90免费格式。使用intel fortran编译器 ifort,编译和运行和以前一样好
我有一个实现用户定义的算术类型的MyType类。此类提供以下转换运算符 struct MyType { ... operator double() { return to_double
我目前正在使用 Cxx 来允许 Julia 代码与 C++ 库交互。我想做的一部分是在两个方向上有效地传递复杂数据的集合(通常是 vector )。也就是说,我想要以下内容: cv = [1 + 2i
假设我有一个名为“汽车”的实体。 我使用复杂类型来定义“引擎”部分。 [TableName("T_CAR")] public sealed class Car:IEngine { ... pu
我想使用 static_cast 将 complex 转换为 complex 。 Convert complex to complex 我正在尝试做与这篇文章相同的事情,但我需要使用 static_c
` ?
对于多项式方程求解器,最好将其模板化为任何可用类型: template class PolynomialEquation { public: private: array myEquatio
为了在 cython 中将实部与复部分开,我通常使用 complex.real 和 complex.imag 来完成这项工作。然而,这确实会在 html 输出中生成颜色为“python red”的代码
我的问题很简单: Are both "complex float" and "float complex" valid C? 两者似乎都被 gcc 接受而没有警告。 最佳答案 complex 是 co
以下声明有什么区别? 结构体 *ptr1=(结构体*)malloc(4*sizeof(结构体)); 结构体 (*ptr1)[4]=(结构体*)malloc(sizeof(结构体)); 哪个更好用? 最
我想创建一个 C++ 类的复数。这里是Complex.h(最基本的形式) #ifndef _COMPLEX #define _COMPLEX #include "TVector2.h" class C
我已经使用 Visual Studio 2012 和 NDepend 对我的解决方案进行了代码分析 对于方法 MethodA,Visual Studio 显示复杂度为 105,Ndepend 显示为
我的代码: #include using std::cin; using std::cout; using std::istream; using std::ostream; template cl
我在 swift3 中有以下代码,我正在使用 swift lint 对代码进行 linting。给出代码如下: func selectedMenuInLoggedOutState(sender
我是一名优秀的程序员,十分优秀!