具有非不同键的直接地址表
Direct address table with non-distinct keys
本文关键字:地址 更新时间:2023-10-16
我正在研究一个练习问题,涉及设计一个直接地址表,可能具有不同的键。约束是 INSERT、DELETE 和 SEARCH 应该在 O(1) 时间内运行;参数是指向设置对象的指针。
一个明显的解决方案是使用链接,表条目指向链表的头部(可以是 NULL)。使用这样的链接,INSERT 和 DELETE 肯定会在 O(1) 时间内运行,但是,SEARCH 不会...任何建议将不胜感激。
研究 STL 关联容器的设计 std::unordered_set, std:unordered_map, std::
unordered_multiset, std::unorderd_multimap 取决于你是要存储 {unique, non-unique} 还是 {key, key-values}。如果你没有 C++11 编译器(例如 MSVC++>= 2010 或 gcc>= 4.4),你可以使用 Boost.Unordered。
更新:如果您专门寻找 C 库:请查看 http://attractivechaos.wordpress.com/2008/09/02/implementing-generic-hash-library-in-c/
相关文章:
- 将数组的地址分配给变量并删除
- 空基优化子对象的地址
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 如何在c++程序中找到函数的地址
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 被解释为低级别const的const对象的地址
- 将地址分配给本地指针后,公共对象的变量将消失
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 内联程序集printf将整数解释为地址
- 为什么指针不写入类的地址?
- 如何在C++中获取该对象的类声明中对象的地址?
- 通过按地址访问变量
- 当一个新对象被分配到它的地址时,对象是否必须被销毁
- 函数名是c中该函数的第一条指令的地址吗
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- ReadProcessMemory() 不适用于像 0x2840C6C68D8 这样的长地址
- CUDA:统一内存和指针地址的更改
- 当我们从/tp地址中添加/减去一个整数时会发生什么
- 如何使用 Boost Asio 在 Android 上获取我的本地 udp IP 地址?