news 2026/6/23 3:28:31

set关联式容器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
set关联式容器
作为一个容器也是用来存储同一数据类型的数据类型,并且能从一个数据集合中取出数据,在 中每个元素的值都唯一,而且系统能根据元素的值自动进行排序。应该注意的是 中数元素的值不能直接被改变。与 的使用方法大致都相同。

set的定义

set<类型> 对象名; 如:set<int> s;

添加元素

set<int> s; s.insert(8); s.insert(10); s.insert(6); s.insert(8); //重复元素不会插入

set遍历

set 的遍历也是使用迭代器进行遍历, 可以正序遍历也可以反序遍历。

正序遍历

set<int> s; set<int>::iterator it; for (it = s.begin(); it != s.end(); it++) cout << *it << endl;

反序遍历

set<int>::reverse_iterator it; for (it = s.rbegin(); it != s.rend(); it++) cout << *it << endl

常用操作

begin(), //返回set容器的第一个元素 end(), //返回set容器的最后一个元素 clear(), //删除set容器中的所有的元素 empty(), //判断set容器是否为空 max_size(), //返回set容器可能包含的元素最大个数 size(), //返回当前set容器中的元素个数 rbegin(), //返回的值和end()相同 rend(), //返回的值和begin()相同 erase(iterator), //删除定位器iterator指向的值 erase(first,second), //删除定位器first和second之间的值 erase(key_value), //删除键值key_value的值 find() , //返回给定值值得定位器,如果没找到则返回end()。 set中还有两个非常重要的函数,lower_bound()和upper_bound()。这两个函数都需要传入一个值。 lower_bound返回的是大于或等于被查询元素的第一个元素位置的迭代器,如果找不到,迭代器则为set.end() 。 upper_bound返回值则是>给定val的最小指针(iterator)。 rbegin() 和 rend()为反向迭代器。

因为 set中的元素本身是有序的,因此 begin() 会直接返回集合中最小的元素的位置,而 end()-- 返回的是集合中最大元素的位置。

同排序函数相同,我们可以自行定义比较的方法,但具体使用同 sort 略有不同,需要自己定义一个 struct 来做具体类型的比较,同时要定义一个名为 operator 的 bool 类型函数,具体请看下面的代码。

#include <bits/stdc++.h> using namespace std; //自定义比较结构体 struct Cmp { bool operator()(int l, int r) { return l % 10 > r % 10; } }; int main() { set<int, Cmp> s; for(int i = 7; i < 27; i++) s.insert(i); set<int>::iterator it; for (it = s.begin(); it != s.end(); it++) cout << *it << endl; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 2:46:35

一键解锁阅读3.0书源终极合集:1629个精品资源任你选

一键解锁阅读3.0书源终极合集&#xff1a;1629个精品资源任你选 【免费下载链接】最新1629个精品书源.json阅读3.0 最新1629个精品书源.json阅读3.0 项目地址: https://gitcode.com/open-source-toolkit/d4322 还在为找不到优质书源而烦恼吗&#xff1f;想要在阅读3.0中…

作者头像 李华
网站建设 2026/6/23 22:04:25

一般人不懂Windows

如果以下全会&#xff0c;给你竖大拇哥。

作者头像 李华
网站建设 2026/6/23 11:12:41

Java 基于多线程机制的专项实验

2.1 验证性实验1、利用两种方式实现多线程&#xff1a;(1) 第一种方式&#xff1a;继承Thread类(2) 第二种方式&#xff1a;继承 java.lang.Runnable 接口第一种方式&#xff1a;public class Test1 {public static void main(String[] args) throws InterruptedException { /…

作者头像 李华
网站建设 2026/6/23 21:29:05

51、Linux 系统中 shell 环境管理与脚本编写全解析

Linux 系统中 shell 环境管理与脚本编写全解析 在 Linux 系统的使用过程中,对 shell 环境进行有效管理以及编写实用的 shell 脚本,能够极大地提升工作效率,让操作更加便捷和自动化。下面将详细介绍 shell 环境管理的相关内容,包括永久修改 shell 提示符、使用命令别名、修改…

作者头像 李华
网站建设 2026/6/23 7:44:16

53、编写高效 Shell 脚本:从基础到实践

编写高效 Shell 脚本:从基础到实践 1. 使用 case 语句处理用户输入 在脚本编写中, case 语句是处理多变量值的强大工具。例如,在修改后的 mkuser.sh 脚本中,用户可以输入要创建的用户名,或者输入 Exit 来退出脚本。 case 语句会检查输入是否为 Exit ,如果是…

作者头像 李华
网站建设 2026/6/23 3:44:25

解锁共享单车数据:从入门到精通的完整分析指南

还在为找不到合适的交通数据分析项目而烦恼吗&#xff1f;想要通过真实案例提升数据技能&#xff1f;这个精心整理的共享单车数据集正是你需要的实践宝库&#xff01;&#x1f3af; 【免费下载链接】国内某共享单车数据集 这是一个专门为交通行业学生设计的国内共享单车数据集&…

作者头像 李华