C++ STL集合并发函数详解与实例
需积分: 22 130 浏览量
更新于2024-07-17
1
收藏 38KB DOCX 举报
"C++STL常见方法的详细总结,包括集合(set)的使用,适合学习C++ STL竞赛编程的人员参考。文档全面介绍了set的基本概念、排序规则、元素存储及迭代器成员函数的用法。"
C++ Standard Template Library (STL) 是一个强大的库,提供了多种数据结构和算法,极大地简化了C++编程。在这个文档中,重点是集合(set),它是一个基于红黑树的数据结构,用于存储唯一元素,并按照特定的比较规则进行排序。
1. 集合(set)的定义与特性
- 集合由节点组成,每个节点包含一个元素。
- 节点之间的排序基于元素对的谓词,确保没有两个元素具有相同的次序,即元素的互异性。
- 默认情况下,集合按小于号排序(升序)。可以通过指定第二个模板参数如`set<int, less<int>>`来保持升序,或者使用`greater<int>`实现降序排列。
- 存储字符串时,应使用C++的`string`类,而不是`char*`指针。
2. 集合(set)的初始化
- 可以通过数组直接初始化集合,例如`set<int> st(a, a+10)`。
3. 集合(set)的成员函数
- `begin()`:返回指向集合中第一个元素的迭代器。
- `end()`:返回指向最后一个元素后面的位置的迭代器,通常用于结束循环。
- `find(…)`:查找指定元素,返回一个迭代器指向找到的元素,若未找到则返回`end()`。
```cpp
set<int> s;
set<int>::iterator it = s.find(5);
if (it != s.end()) cout << *it << endl; // 找到
else cout << "未找到"; // 未找到
```
- 迭代器的使用:通过`for`循环遍历集合中的所有元素,包括正向迭代器`iterator`和反向迭代器`reverse_iterator`。
```cpp
// 正向迭代器遍历
for (set<int>::iterator it = st.begin(); it != st.end(); it++) cout << *it;
// 反向迭代器遍历
for (set<string>::reverse_iterator it = st.rbegin(); it != st.rend(); it++)
cout << *it;
```
- `rbegin()` 返回反向迭代器,指向集合的最后一个元素,`rend()` 返回反向迭代器,指向第一个元素的前一个位置。
这个文档为学习C++ STL的同学提供了一个全面的集合(set)用法概述,对于参加编程比赛或需要高效处理唯一数据的场合尤其有用。了解并熟练运用这些方法,能有效提升编程效率和代码质量。
2017-12-07 上传
2023-04-05 上传
2023-07-16 上传
2023-11-28 上传
2023-12-27 上传
2023-09-17 上传
2023-08-26 上传
qq_36595455
- 粉丝: 0
- 资源: 1
最新资源
- JDK 17 Linux版本压缩包解压与安装指南
- C++/Qt飞行模拟器教员控制台系统源码发布
- TensorFlow深度学习实践:CNN在MNIST数据集上的应用
- 鸿蒙驱动HCIA资料整理-培训教材与开发者指南
- 凯撒Java版SaaS OA协同办公软件v2.0特性解析
- AutoCAD二次开发中文指南下载 - C#编程深入解析
- C语言冒泡排序算法实现详解
- Pointofix截屏:轻松实现高效截图体验
- Matlab实现SVM数据分类与预测教程
- 基于JSP+SQL的网站流量统计管理系统设计与实现
- C语言实现删除字符中重复项的方法与技巧
- e-sqlcipher.dll动态链接库的作用与应用
- 浙江工业大学自考网站开发与继续教育官网模板设计
- STM32 103C8T6 OLED 显示程序实现指南
- 高效压缩技术:删除重复字符压缩包
- JSP+SQL智能交通管理系统:违章处理与交通效率提升