C++中的`unordered_set`是一个无序的集合容器,用于存储唯一的元素。它存储的元素类型可以是任意自定义类型,包括保存两个变量的情况。
要保存两个变量,可以使用自定义结构体或类作为`unordered_set`的元素类型。下面是一个使用自定义结构体的示例:
```cpp
#include #include struct MyPair { int x; int y; }; struct MyPairHash { size_t operator()(const MyPair& pair) const { return std::hash } }; struct MyPairEqual { bool operator()(const MyPair& lhs, const MyPair& rhs) const { return lhs.x == rhs.x && lhs.y == rhs.y; } }; int main() { std::unordered_set mySet.insert({1, 2}); mySet.insert({3, 4}); mySet.insert({1, 2}); // 重复的元素不会被插入 for (const auto& pair : mySet) { std::cout < pair x="">< ",="" "="">< pair y=""><> } return 0; } ``` 在上面的示例中,`MyPair`是自定义的结构体,包含两个整数类型的成员变量`x`和`y`。`MyPairHash`是自定义的哈希函数,用于计算`MyPair`类型的哈希值。`MyPairEqual`是自定义的相等比较函数,用于判断`MyPair`类型的元素是否相等。 在`main`函数中,创建了一个`unordered_set`对象`mySet`,并使用`insert`函数插入了几个`MyPair`类型的元素。注意,重复的元素不会被插入,因为`unordered_set`中的元素是唯一的。 最后,使用范围`for`循环遍历`mySet`,并输出每个`MyPair`类型元素的成员变量`x`和`y`的值。 你可以根据自己的需求自定义`MyPair`结构体的成员变量和哈希函数、相等比较函数。