命名空间
变体
操作

operator==,!=(std::unordered_multimap)

来自 cppreference.cn
 
 
 
 
template< class Key, class T, class Hash, class KeyEqual, class Alloc >

bool operator==( const std::unordered_multimap<Key, T, Hash, KeyEqual, Alloc>& lhs,

                 const std::unordered_multimap<Key, T, Hash, KeyEqual, Alloc>& rhs );
(1)
template< class Key, class T, class Hash, class KeyEqual, class Alloc >

bool operator!=( const std::unordered_multimap<Key, T, Hash, KeyEqual, Alloc>& lhs,

                 const std::unordered_multimap<Key, T, Hash, KeyEqual, Alloc>& rhs );
(2) (C++20 前)

比较两个无序容器的内容。

当满足以下条件时,两个无序容器 lhsrhs 的内容相等:

  • lhs.size() == rhs.size().
  • lhs.equal_range(lhs_eq1) 获得的每个等价元素组 [lhs_eq1lhs_eq2) 在另一个容器中存在一个对应的等价元素组 [rhs_eq1rhs_eq2),该组从 rhs.equal_range(rhs_eq1) 获得,并具有以下属性:

如果 `Key` 或 `T` 不满足 EqualityComparable,则行为未定义。

如果 `hash_function()` 和 `key_eq()` 在 lhsrhs 上的行为不同,(直到 C++20)`key_eq()` 在 lhsrhs 上的行为不同,(自 C++20 起) 或者如果 `Key` 的 operator== 不是由 `key_eq()` 引入的等价键组分区的细化(即,如果两个使用 operator== 比较相等的元素落入不同的分区),则行为也未定义。

!= 运算符由 operator== 合成

(C++20 起)

[编辑] 参数

lhs, rhs - 要比较的无序容器

[编辑] 返回值

1) 如果容器内容相等则为 true,否则为 false
2) 如果容器内容不相等则为 true,否则为 false

[编辑] 复杂度

平均情况下,与 `value_type` 上的 operator== 调用次数,由 key_eq 返回的谓词调用次数,以及由 hash_function 返回的哈希器调用次数的 ΣSi2 成比例,其中 S 是第 i 个等价键组的大小。最坏情况下,与 N2 成比例,其中 N 是容器的大小。如果每个等价键组中的元素按相同顺序排列(当容器是彼此的副本时发生),则平均情况与 N 成比例。