菜单
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

C++ 教程

C++ 主页 C++ 简介 C++ 入门 C++ 语法 C++ 输出 C++ 注释 C++ 变量 C++ 用户输入 C++ 数据类型 C++ 运算符 C++ 字符串 C++ 数学 C++ 布尔值 C++ If...Else C++ Switch C++ While 循环 C++ For 循环 C++ Break/Continue C++ 数组 C++ 结构体 C++ 枚举 C++ 引用 C++ 指针

C++ 函数

C++ 函数 C++ 函数参数 C++ 函数重载 C++ 作用域 C++ 递归

C++ 类

C++ OOP C++ 类/对象 C++ 类方法 C++ 构造函数 C++ 访问修饰符 C++ 封装 C++ 继承 C++ 多态 C++ 文件 C++ 异常 C++ 日期

C++ 数据结构

C++ 数据结构与 STL C++ Vectors C++ List C++ Stacks C++ Queues C++ Deque C++ Sets C++ Maps C++ 迭代器 C++ 算法

C++ How To

C++ 两数相加 C++ 随机数

C++ 参考

C++ 参考 C++ 关键字 C++ <iostream> C++ <fstream> C++ <cmath> C++ <string> C++ <cstring> C++ <ctime> C++ <vector> C++ <algorithm>

C++ 示例

C++ 示例 C++ 现实生活中的例子 C++ 编译器 C++ 练习 C++ 测验 C++ 证书


C++ 集合


C++ 集合 (Set)

Set 存储唯一元素,这些元素

  • 会自动按升序排序。
  • 是唯一的,这意味着相等或重复的值将被忽略。
  • 可以添加或删除,但现有元素的值不能被更改。
  • 不能通过索引号访问,因为顺序是基于排序而非索引的。

要使用 set,您必须包含 <set> 头文件

// 包含 set 库
#include <set>

创建集合

要创建 set,请使用 set 关键字,并在尖括号 <> 中指定它应该存储的**类型**,然后是 set 的名称,例如:set<type> setName

示例

// 创建一个名为 cars 的 set,它将存储字符串
set<string> cars;

如果您想在声明时就添加元素,请将它们放在花括号 {} 中,用逗号分隔的列表中

示例

// 创建一个名为 cars 的 set,它将存储字符串
set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 打印 set 元素
for (string car : cars) {
  cout << car << "\n";
}

输出将是:

宝马
福特
Mazda
沃尔沃
自己动手试一试 »

从上面的结果可以看出,set 中的元素会自动排序。在这种情况下,因为我们处理的是字符串,所以是按字母顺序排序的。

如果您将整数存储在 set 中,返回的值将按数字顺序排序

示例

// 创建一个名为 numbers 的 set,它将存储整数
set<int> numbers = {1, 7, 3, 2, 5, 9};

// 打印 set 元素
for (int num : numbers) {
  cout << num << "\n";
}

输出将是:

1
2
3
5
7
9
自己动手试一试 »

注意: set 的类型(例如上面示例中的 stringint)一旦声明就无法更改。


按降序对 Set 进行排序

默认情况下,set 中的元素按升序排序。如果要反转顺序,可以使用尖括号内的 greater<type> 仿函数,如下所示

示例

// 按降序对 set 中的元素进行排序
set<int, greater<int>> numbers = {1, 7, 3, 2, 5, 9};
// 打印元素
for (int num : numbers) {
  cout << num << "\n";
}

输出将是:

9
7
5
3
2
1
自己动手试一试 »

注意: greater<type> 中指定的类型必须与 set 中元素的类型(我们示例中的 int)相匹配。



唯一元素

Set 中的元素是唯一的,这意味着它们不能重复或相等。

例如,如果我们尝试两次将 "BMW" 添加到 set 中,重复的元素将被忽略

示例

set<string> cars = {"Volvo", "BMW", "Ford", "BMW", "Mazda"};

// 打印 set 元素
for (string car : cars) {
  cout << car << "\n";
}

输出将是:

宝马
福特
Mazda
沃尔沃
自己动手试一试 »

添加元素

要向 set 添加元素,您可以使用 .insert() 函数

示例

set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 添加新元素
cars.insert("Tesla");
cars.insert("VW");
cars.insert("Toyota");
cars.insert("Audi");
自己动手试一试 »

移除元素

要从 set 中删除特定元素,您可以使用 .erase() 函数

示例

set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 删除元素
cars.erase("Volvo");
cars.erase("Mazda");
自己动手试一试 »

要删除 set 中的所有元素,您可以使用 .clear() 函数

示例

set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

// 删除所有元素
cars.clear();
自己动手试一试 »

查找 Set 的大小

要查找 set 中有多少个元素,请使用 .size() 函数

示例

set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cout << cars.size();  // 输出 4
自己动手试一试 »

检查 Set 是否为空

使用 .empty() 函数来判断 set 是否为空。

.empty() 函数在 set 为空时返回 1 (true),否则返回 0 (false)

示例

set<string> cars;
cout << cars.empty();  // 输出 1 (Set 为空)
自己动手试一试 »

示例

set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};
cout << cars.empty();  // 输出 0 (非空)
自己动手试一试 »

遍历 Set

您可以使用 **for-each 循环**来遍历 set

示例

set<string> cars = {"Volvo", "BMW", "Ford", "Mazda"};

for (string car : cars) {
  cout << car << "\n";
}
自己动手试一试 »

提示: 也可以使用 迭代器 遍历 set,您将在后面的章节中了解更多。



×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持