0

0

c++ set容器的用法和遍历_c++ set容器使用指南

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-09-30 17:28:02

|

370人浏览过

|

来源于php中文网

原创

set是基于红黑树的有序去重容器,支持O(log n)插入、删除与查找。1. 需包含头文件,可自定义排序如std::greater;2. 支持列表、区间等初始化方式;3. 常用操作有insert、erase、find、count等;4. 遍历可用范围for循环或正向/反向迭代器;5. 元素不可修改,自定义类型需重载

c++ set容器的用法和遍历_c++ set容器使用指南

在C++中,set 是一个非常实用的关联式容器,它能自动对插入的元素进行排序,并保证元素的唯一性。set底层通常基于红黑树实现,因此插入、删除和查找操作的时间复杂度为 O(log n)。本文将详细介绍 set 容器的基本用法和遍历方式,帮助你高效使用它。

1. set 的基本定义与初始化

要使用 set,需要包含头文件 。定义一个 set 非常简单:

std::set mySet;

你也可以指定自定义排序规则,比如让 set 按降序排列

立即学习C++免费学习笔记(深入)”;

std::set> descendingSet;

支持的初始化方式包括:

LangChain
LangChain

一个开源框架,用于构建基于大型语言模型(LLM)的应用程序。

下载
  • 空初始化:std::set s;
  • 列表初始化:std::set s = {3, 1, 4, 1, 5}; // 自动去重并排序
  • 从区间构造:std::set s(v.begin(), v.end());

2. 常用操作函数

set 提供了丰富的成员函数来管理数据:

  • insert(value):插入一个元素,若已存在则不插入
  • erase(value):删除指定值的元素
  • find(value):查找元素,返回迭代器,未找到返回 end()
  • count(value):判断元素是否存在(返回 0 或 1)
  • size():返回元素个数
  • empty():判断是否为空
  • clear():清空所有元素

示例:

mySet.insert(10);
mySet.insert(5);
mySet.insert(10); // 重复,不会插入
if (mySet.find(5) != mySet.end()) {
  std::cout }

3. set 的遍历方法

由于 set 中的元素是自动排序的,遍历时会按顺序访问。常用的遍历方式有以下几种:

  • 范围 for 循环(推荐)
    for (const auto& elem : mySet) {
      std::cout }
  • 使用迭代器正向遍历
    for (auto it = mySet.begin(); it != mySet.end(); ++it) {
      std::cout }
  • 反向遍历
    for (auto rit = mySet.rbegin(); rit != mySet.rend(); ++rit) {
      std::cout }

4. 注意事项与技巧

使用 set 时需要注意一些细节:

  • 元素类型必须支持比较操作(默认使用
  • 不能通过迭代器修改 set 中的值(因为会影响排序结构),*it = newValue; 是非法的
  • 如果需要存储自定义类型,需提供比较函数或重载
  • multiset 允许重复元素,行为类似 set 但允许 count > 1

例如定义结构体并用于 set:

struct Person {
  std::string name;
  int age;
  bool operator };
std::set people;

基本上就这些。掌握 set 的插入、查找和遍历,能大幅提升编码效率,尤其适用于去重和有序存储场景。不复杂但容易忽略细节,多练习几次就能熟练使用。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1427

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

221

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

69

2025.10.17

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

697

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

191

2023.11.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

515

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Rust 教程
Rust 教程

共28课时 | 3.8万人学习

Git 教程
Git 教程

共21课时 | 2.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号