std::字符串不等式实现的std::集
std::set of std::string inequality implementation
由于std::set
是作为二叉树实现的,它如何比较std::string
的不等式?它看起来像a < b && b < a
吗?
它是直接使用字符串的长度,还是以某种方式对其进行哈希处理?它能保证字符串的唯一性吗?
它只需要做更少的两次比较——用左和右交换第二次比较。如果两者都返回false,则认为字符串相等。
是的,它确实保证了它的成员(包括字符串)的唯一性,只要无运算符对成员类型执行预期的操作(当然对字符串是这样,但对用户定义的类型可能不是这样)。
std::set
使用less
对其键进行排序。这是std::string
上的operator<
,它按字典方式比较字符串。
相关文章:
- 使用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::valarray和不等式
- std::字符串不等式实现的std::集