C++ 中的 std::set
是一个关联容器,它包含一组唯一的对象。std::set
通过比较函数(默认为 std::less
,即升序比较)来确保其包含的元素是唯一的。当你尝试向 std::set
中插入一个已经存在的元素时,std::set
不会接受这个元素,因此保证了元素的唯一性。
以下是一个简单的示例,展示了如何使用 std::set
来存储唯一的整数:
#include <iostream>
#include <set>
int main() {
std::set<int> my_set = {1, 2, 3, 4, 5};
// 尝试插入一个已经存在的元素
my_set.insert(3);
// 输出集合中的元素
for (const int& element : my_set) {
std::cout << element << " ";
}
return 0;
}
输出结果:
1 2 3 4 5
在这个例子中,尽管我们尝试插入了元素 3
,但 std::set
只接受了这个元素,因为它已经在集合中了。所以输出结果中并没有重复的元素。