<unordered_set> 运算符

标头 <unordered_set> 提供以下运算符:

operator!=

测试运算符左侧的对象是否 unordered_set 不等于 unordered_set 右侧的对象。

bool operator!=(const unordered_set <Key, Hash, Pred, Allocator>& left, const unordered_set <Key, Hash, Pred, Allocator>& right);

参数

left
一个 unordered_set 类型的对象。

right
一个 unordered_set 类型的对象。

返回值

true unordered_set如果 s 不相等,则为 equal;false如果相等。

备注

对象之间的 unordered_set 比较不受存储其元素的任意顺序的影响。 如果两个元素具有相同数量的元素,并且一个容器中的元素是另一个容器中元素的排列,则两 unordered_set者相等。 否则,它们不相等。

示例

// unordered_set_ne.cpp
// compile by using: cl.exe /EHsc /nologo /W4 /MTd
#include <unordered_set>
#include <iostream>
#include <ios>

int main()
{
    using namespace std;

    unordered_set<char> c1, c2, c3;

    c1.insert('a');
    c1.insert('b');
    c1.insert('c');

    c2.insert('c');
    c2.insert('a');
    c2.insert('d');

    c3.insert('c');
    c3.insert('a');
    c3.insert('b');

   cout << boolalpha;
   cout << "c1 != c2: " << (c1 != c2) << endl;
   cout << "c1 != c3: " << (c1 != c3) << endl;
   cout << "c2 != c3: " << (c2 != c3) << endl;

    return (0);
}
c1 != c2: true
c1 != c3: false
c2 != c3: true

operator==

测试运算符左侧的对象是否 unordered_set 等于 unordered_set 右侧的对象。

bool operator==(const unordered_set <Key, Hash, Pred, Allocator>& left, const unordered_set <Key, Hash, Pred, Allocator>& right);

参数

left
一个 unordered_set 类型的对象。

right
一个 unordered_set 类型的对象。

返回值

true unordered_set如果 s 相等,则为 1;false如果它们不相等。

备注

对象之间的 unordered_set 比较不受存储其元素的任意顺序的影响。 如果两个元素具有相同数量的元素,并且一个容器中的元素是另一个容器中元素的排列,则两 unordered_set者相等。 否则,它们不相等。

示例

// unordered_set_eq.cpp
// compile by using: cl.exe /EHsc /nologo /W4 /MTd
#include <unordered_set>
#include <iostream>
#include <ios>

int main()
{
    using namespace std;

    unordered_set<char> c1, c2, c3;

    c1.insert('a');
    c1.insert('b');
    c1.insert('c');

    c2.insert('c');
    c2.insert('a');
    c2.insert('d');

    c3.insert('c');
    c3.insert('a');
    c3.insert('b');

   cout << boolalpha;
   cout << "c1 == c2: " << (c1 == c2) << endl;
   cout << "c1 == c3: " << (c1 == c3) << endl;
   cout << "c2 == c3: " << (c2 == c3) << endl;

    return (0);
}
c1 == c2: false
c1 == c3: true
c2 == c3: false

operator!= (多集)

测试运算符左侧的对象是否 unordered_multiset 不等于 unordered_multiset 右侧的对象。

bool operator!=(const unordered_multiset <Key, Hash, Pred, Allocator>& left, const unordered_multiset <Key, Hash, Pred, Allocator>& right);

参数

left
一个 unordered_multiset 类型的对象。

right
一个 unordered_multiset 类型的对象。

返回值

true unordered_multiset如果 s 不相等,则为 equal;false如果相等。

备注

对象之间的 unordered_multiset 比较不受存储其元素的任意顺序的影响。 如果两个元素具有相同数量的元素,并且一个容器中的元素是另一个容器中元素的排列,则两 unordered_multiset者相等。 否则,它们不相等。

示例

// unordered_multiset_ne.cpp
// compile by using: cl.exe /EHsc /nologo /W4 /MTd
#include <unordered_set>
#include <iostream>
#include <ios>

int main()
{
    using namespace std;

    unordered_multiset<char> c1, c2, c3;

    c1.insert('a');
    c1.insert('b');
    c1.insert('c');
    c1.insert('c');

    c2.insert('c');
    c2.insert('c');
    c2.insert('a');
    c2.insert('d');

    c3.insert('c');
    c3.insert('c');
    c3.insert('a');
    c3.insert('b');

   cout << boolalpha;
   cout << "c1 != c2: " << (c1 != c2) << endl;
   cout << "c1 != c3: " << (c1 != c3) << endl;
   cout << "c2 != c3: " << (c2 != c3) << endl;

    return (0);
}
c1 != c2: true
c1 != c3: false
c2 != c3: true

operator== (多集)

测试运算符左侧的对象是否 unordered_multiset 等于 unordered_multiset 右侧的对象。

bool operator==(const unordered_multiset <Key, Hash, Pred, Allocator>& left, const unordered_multiset <Key, Hash, Pred, Allocator>& right);

参数

left
一个 unordered_multiset 类型的对象。

right
一个 unordered_multiset 类型的对象。

返回值

true unordered_multiset如果 s 相等,则为 1;false如果它们不相等。

备注

对象之间的 unordered_multiset 比较不受存储其元素的任意顺序的影响。 如果两个元素具有相同数量的元素,并且一个容器中的元素是另一个容器中元素的排列,则两 unordered_multiset者相等。 否则,它们不相等。

示例

// unordered_multiset_eq.cpp
// compile by using: cl.exe /EHsc /nologo /W4 /MTd
#include <unordered_set>
#include <iostream>
#include <ios>

int main()
{
    using namespace std;

    unordered_multiset<char> c1, c2, c3;

    c1.insert('a');
    c1.insert('b');
    c1.insert('c');
    c1.insert('c');

    c2.insert('c');
    c2.insert('c');
    c2.insert('a');
    c2.insert('d');

    c3.insert('c');
    c3.insert('c');
    c3.insert('a');
    c3.insert('b');

   cout << boolalpha;
   cout << "c1 == c2: " << (c1 == c2) << endl;
   cout << "c1 == c3: " << (c1 == c3) << endl;
   cout << "c2 == c3: " << (c2 == c3) << endl;

    return (0);
}
c1 == c2: false
c1 == c3: true
c2 == c3: false