c++中的set容器介绍及操作大全

2025-06-25 05:50
文章标签 c++ 介绍 操作 set 大全 容器

本文主要是介绍c++中的set容器介绍及操作大全,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧...

​​一、核心特性

​唯一性与自动排序​
std::set存储的元素​​唯一且默认升序排列​​(通过std::less实现)。插入重复元素会被自动忽略:

set<int> s = {3, 1, 2, 2}; // 实际存储 {1, 2, 3}
  • ​底层实现​​:红黑树(自平衡二叉搜索树),保证插入、删除、查找的​​时间复杂度为O(log n)​

​元素不可修改​
元素值即键(Key),修改会破坏红黑树结构。迭代器类型为const_iterator,禁止写操作:

auto it = s.find(2);
*it = 4; // 编译错误!元素不可直接修改
  • http://www.chinasem.cn改的正确姿势​​:先删除旧值,再插入新值
  1. ​无随机访问​
    不支持operator[]或下标访问,遍历​​必须依赖迭代器​​(双向迭代器,仅支持++/--

️ ​​二、基本操作​​

​​1. 初始化与赋值​​

​方式​​示例​
默认构造set<int> s;
初始化列表set<int> s = {1, 3, 2}; → {1, 2, 3}
迭代器范围初始化vector<int> v{5,4,3}; s编程et<int> s(v.begin(), v.end());
自定义排序规则set<int, greater<int>> s;(降序)

4

12

​​2. 增删查操作​​

​操作​​函数​​示例​​返回值​
插入元素insert(value)s.insert(4);pair<iter, bool>(成功时bool=true
删除元素erase(key) / erase(iter)s.erase(3); 或 s.erase(s.begin());返回被删元素后的迭代器
查找元素find(key)auto it = s.find(2);找到返回迭代器,否则返回s.end()
统计元素存在性count(key)if (s.count(2)) { ... }01(因元素唯一)

1

9

​​3. 遍历方式​​

// 迭代器遍历
for (auto it = s.begin(); it != s.end(); ++it) {
    cout << *it << " ";
}
// 范围循环(C++11)
for (int val : s) {
    cout << val << " ";
}

⚙️ ​​三、高级操作​​

​​1. 自定义排序规则​​

通过函数对象或Lambda实现复杂排序:

struct CaseInsensitiveCompare {
    bool operator()(const string& a, const string& b) const {
        return tolower(a[0]) < tolower(b[0]); // 首字母不区分大小写
    }
};
set<string, CaseInsensitiveCompare> s;

​​2. 范围查询(lower_bound / upper_bound)​​

set<int> s = {10, 20, 30, 40};
auto low = s.lower_bound(20); // 首个 ≥20 的元素 → 20
auto high = s.upper_bound(30); // 首个 >30 的元素 → 40
  • ​应用场景​​:快速定位有序数据中的区间

​​3. 结构体存储​​

需重载operator<

struct Person {
    string name;
    int age;
    bool operator<(const Person& p) const { 
        return age < p.age; // 按年龄升序
    }
};
set<Person> s = {{"Alice", 30}, {"Bob", 25}};

⚖️ ​​四、性能对比:set vs vector​​

​操作​setvector​适用场景​
​插入/删除​O(log n)(任意位置)O(n)(非尾部操作)频繁中间插入/删除 → ​​选set
​查找​O(log n)(二分查找)O(n)(线性遍历)高频查找 → ​​选set
​随机访问​❌ 不支持✅ O(1)按索引访问 → ​​选vector
​内存占用​较高(树节点开销)较低(连续内存)内存敏感 → ​​选vector
​元素顺序​自动排序插入顺序需有序 → ​​选set

​关键结论​​:

  • ​唯一性+有序性​​需求优先选set
  • ​随机访问+连续存储​​需求优先选vector

​​五、典型应用场景​​

​数据去重与排序​
从重复数据中提取唯一有序序列:

vector<int> data = {5, 3, 5, 2, 1};
set<int> unique_sorted(data.begin(), data.end()); // {1, 2, 3, 5}

​高效存在性检查​
黑名单/白名单快速过滤:

set<string> blacklist = {"user1", "user2"};
if (blacklist.find(input_user) != blacklist.end()) block_user();

​范围统计与区间查询​
成绩分级、区间数据分析:

set<int> scores = {60, 75, 85, 90};
auto pass = scores.lower_bound(60); // ≥60的第一个元素

⚠️ ​​六、避坑指南​​

  • ​迭代器失效问题​

删除元素时,​​仅被删元素的迭代器失效​​,其他迭代器仍有效。

  • ​无android法修改元素值​

“修改”需先删除再插入:

auto it = s.find(old_val);
if (it != s.end()) 编程{
    s.erase(it);
    s.insert(new_val); // 安全修改
}
  • ​​自定义类型必须重载operator<​​
  • 否则编译失败(红黑树需比较规则)。

​总结​

  • ​核心优势​​:自动去重、有序存储、O(log n)高效操作;
  • ​核心局China编程限​​:无随机访问、内存开销较高;
  • ​替代方案​​:
    • 需重复元素 → multiset
    • 需O(1)查找 → unordered_set(哈希表实现,无序)。

到此这篇关于c++中的set容器介绍及操作大全的文章就介绍到这了,更多相关c++ set容器内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于c++中的set容器介绍及操作大全的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155209

相关文章

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Python内存管理机制之垃圾回收与引用计数操作全过程

《Python内存管理机制之垃圾回收与引用计数操作全过程》SQLAlchemy是Python中最流行的ORM(对象关系映射)框架之一,它提供了高效且灵活的数据库操作方式,本文将介绍如何使用SQLAlc... 目录安装核心概念连接数据库定义数据模型创建数据库表基本CRUD操作创建数据读取数据更新数据删除数据查

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

5 种使用Python自动化处理PDF的实用方法介绍

《5种使用Python自动化处理PDF的实用方法介绍》自动化处理PDF文件已成为减少重复工作、提升工作效率的重要手段,本文将介绍五种实用方法,从内置工具到专业库,帮助你在Python中实现PDF任务... 目录使用内置库(os、subprocess)调用外部工具使用 PyPDF2 进行基本 PDF 操作使用

Java JUC并发集合详解之线程安全容器完全攻略

《JavaJUC并发集合详解之线程安全容器完全攻略》Java通过java.util.concurrent(JUC)包提供了一整套线程安全的并发容器,它们不仅是简单的同步包装,更是基于精妙并发算法构建... 目录一、为什么需要JUC并发集合?二、核心并发集合分类与详解三、选型指南:如何选择合适的并发容器?在多

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su