为什么 std::set 不叫 std::binary_tree?
Why isn't std::set just called std::binary_tree?
std::set in C++在数据结构方面不是一个真正的集合。 std::unordered_set 是一个实数集合,但 std::set 是一个二叉搜索树,更具体地说是一棵红黑树。那么,为什么它被称为std::set呢?是否有一些特定的功能可以将 std::set 与二叉树区分开来?谢谢。
为什么 std::set 不叫 std::binary_tree?
因为
- 树不描述如何使用接口。设置确实如此。
std::set
提供的操作不足以用作通用搜索树。它只为搜索树的特定应用程序提供一个接口:集合的表示形式。- 从技术上讲,该标准没有指定
std::set
是一个二叉搜索树;尽管红黑BST可能是唯一可以达到std::set
要求的数据结构,并且接口已经仔细指定了该数据结构,但内部数据结构的选择是一个实现细节。 - 出于同样的原因,
std::unordered_set
不被称为std::hash_table
。
std::unordered_set 是一个实数集合,但 std::set 是一个二叉搜索树
std::unordered_set
并不比std::set
更"真实"。它们都是要求和保证略有不同的套装;一个设计为可使用树实现,另一个设计为可使用哈希表实现。
附言树和哈希表并不是表示集合的唯一方法。可以实现大多数(但不是全部)std::set
的内部数据结构是排序向量。特别是对于小集合,排序向量可以比std::set
快得多。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 如何从 std::atomic 中提取指针 T<T>?
- 为什么 std::unique 不调用 std::sort?
- 使用std::函数映射对象方法
- 可组合的lambda/std::函数与std::可选