0

0

C++怎么使用set容器_C++集合操作教程【高效】

尼克

尼克

发布时间:2026-03-04 13:58:03

|

651人浏览过

|

来源于php中文网

原创

直接用 count() 判断存在性,返回 1 或 0;insert() 返回 pair 的 second 表示是否成功;遍历时删除需用 erase 返回值更新迭代器;有序选 set,快速查存选 unordered_set。

c++怎么使用set容器_c++集合操作教程【高效】

怎么判断一个值是否在 std::set

查是否存在是 std::set 最常用操作,别用 find() 后再比较迭代器——虽然能用,但语义不清还多写两行。直接用 count() 更直白,返回 10,和你想表达的“有没有”完全对应。

注意:count()std::set 永远只返回 01(没有重复),但它底层仍是 O(log n),不是哈希表那种均摊 O(1)。别误以为它快过 unordered_set

常见错误:把 count() 当成返回元素个数的通用接口,结果在 multiset 里才真有多个;但在 set 里这么用没问题,只是别混淆语义。

示例:

<pre class="brush:php;toolbar:false;">std::set<int> s = {1, 3, 5, 7};<br>if (s.count(5)) {<br>    // 存在<br>}

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

插入失败时怎么知道是重复还是内存不足

std::set::insert() 返回一个 <code>std::pair<iterator bool></iterator>,其中 second 才是你该看的标志位:为 true 表示插入成功,false 表示键已存在。它永远不会因为“内存不足”失败——std::set 插入失败只有一种原因:键重复。

真正可能抛异常的是内存分配环节,比如构造时传入自定义分配器且分配失败,但这种情况极少见,标准库通常会抛 std::bad_alloc,不是 insert() 的返回值能反映的。

实操建议:

Pixelfox AI
Pixelfox AI

多功能AI图像编辑工具

下载
  • 永远检查返回值的 .second 字段,而不是靠捕获异常来判断重复
  • 别在循环里反复 insert() 然后忽略返回值——既浪费 O(log n),又掩盖逻辑问题
  • 如果要批量去重插入,考虑先用 std::vector 收集,再用 set 构造函数初始化,效率更高

遍历 std::set 时能不能边遍历边删元素

可以,但必须用返回值接管下一个有效迭代器,不能写 it++ 后再删 it。因为 erase(it) 会让 it 失效,而 it++ 是先取值再递增,此时取到的已是悬垂指针。

正确做法是用 erase() 的返回值——它返回被删元素之后的合法迭代器。C++11 起 std::set::erase(iterator) 就支持这个用法。

示例:

<pre class="brush:php;toolbar:false;">for (auto it = s.begin(); it != s.end(); ) {<br>    if (*it % 2 == 0) {<br>        it = s.erase(it);  // 安全:it 指向下一个<br>    } else {<br>        ++it;<br>    }<br>}

容易踩的坑:

  • 写成 s.erase(it++); —— <code>it 仍会被递增,但 erase 后 it 已无效,行为未定义
  • 在范围 for 循环里调 erase() —— 迭代器自动失效,直接崩溃
  • 误以为 erase(key) 版本也能返回迭代器 —— 它返回删掉的元素个数(size_t),没法用于遍历控制

std::setstd::unordered_set 到底该选哪个

看场景:需要有序遍历、范围查询(比如找所有大于 100 的数)、或频繁做集合运算(set_intersection)就选 std::set;只要快速查存删,且不关心顺序,选 std::unordered_set

性能差异明显:std::set 所有操作都是 O(log n),基于红黑树;std::unordered_set 平均 O(1),但最坏退化到 O(n)(哈希冲突严重时),而且不保证迭代顺序。

兼容性注意点:

  • std::set 要求 key 可比较(默认 operator),<code>unordered_set 要求可哈希(需特化 std::hash
  • 自定义类型用 unordered_set 时,漏写哈希函数或等价判断,编译直接报错,错误信息往往指向内部模板深处,很难定位
  • 如果数据量小(

复杂点在于:有些需求表面要“有序”,其实只是调试时想看整齐输出——这时用 unordered_set + 临时转 vector 排序更轻量;而有些看似只要查存删,但后续要按插入顺序遍历,那就得换容器了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
counta和count的区别
counta和count的区别

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

201

2023.11.20

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1794

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

572

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2340

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.19

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

0

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

24

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

25

2026.03.03

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

77

2026.02.28

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.6万人学习

C 教程
C 教程

共75课时 | 5.1万人学习

C++教程
C++教程

共115课时 | 20.3万人学习

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

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