答案是使用insert()函数向set添加元素,set自动排序并去重。插入单个元素时返回pair,包含迭代器和是否插入成功的布尔值;可通过初始化列表或迭代器范围批量插入;自定义类型需提供比较规则,如重载

在C++中,向set容器中添加元素主要使用insert()成员函数。由于set是关联式容器,它会自动对插入的元素进行排序,并保证元素的唯一性——即不允许重复值存在。
使用 insert() 插入单个元素
insert()是最常用的方法,用于向set中添加一个或多个元素。插入单个元素时,返回一个pair类型,包含指向插入位置的迭代器和一个布尔值,表示是否成功插入。
示例代码:
#include#include using namespace std; int main() { set nums; auto result = nums.insert(10); if (result.second) { cout << "插入 10 成功" << endl; } else { cout << "插入失败,元素已存在" << endl; } nums.insert(5); // 直接插入,不检查结果 nums.insert(15); }
插入多个相同类型的元素
如果需要一次性插入多个元素,可以使用初始化列表或范围插入方式。
立即学习“C++免费学习笔记(深入)”;
- 使用初始化列表:
setnums = {3, 1, 4, 1, 5}; // 重复的1只会保留一个
- 使用迭代器范围插入(例如从vector中批量插入):
vectorvec = {2, 4, 6, 4, 8}; set nums(vec.begin(), vec.end()); // 自动去重并排序
处理自定义类型
若set中存储的是自定义结构体或类,必须提供比较规则,否则编译会报错。可以通过重载运算符或指定比较函数。
例如:
struct Person {
string name;
int age;
bool operator<(const Person& p) const {
return age < p.age; // 按年龄排序
}
};
set people;
people.insert({"Alice", 25});
people.insert({"Bob", 30});
基本上就这些。只要记住set::insert()是主要方法,自动排序和去重是其核心特性,使用起来简单高效。











