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

来自cppreference.com

 
 
 
 
template< class Key, class Hash, class KeyEqual, class Alloc >

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

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

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

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

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

若下列条件成立则两个无序容器 lhsrhs 相等:

  • lhs.size() == rhs.size()
  • lhs.equal_range(lhs_eq1) 获得的每组等价元素 [lhs_eq1lhs_eq2) 拥有在另一容器中从 rhs.equal_range(rhs_eq1) 获得的对应等价元素组 [rhs_eq1rhs_eq2),且它们拥有下列属性:

Key可相等比较 (EqualityComparable) 则行为未定义。

hash_function()key_eq() (C++20 前)key_eq() (C++20 起)lhsrhs 上拥有不相同的行为,或若 Keyoperator== 不是对于 key_eq() 所引入的等价键组的细分(即若用 operator== 比较相等的二个元素落入不同划分),则行为未定义。

!= 运算符从 operator== 运算符合成

(C++20 起)

参数

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

返回值

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

复杂度

调用 value_type 上的 operator==、调用 key_eq 所返回的谓词,及调用 hash_function 所返回的散列器的次数,平均情况下与 N 成正比,最坏情况下与 N2 成正比,其中 N 是容器大小。