【C++关联容器】set的成员函数

news2025/1/15 23:44:44

目录

set

1. 构造、析构和赋值运算符重载

1.1 构造函数

1.2 析构函数

1.3 赋值运算符重载

2. 迭代器

3. 容量

4. 修改器

5. 观察者

6. 操作

7. 分配器


set

set是按照特定顺序存储唯一元素的容器。

在一个set中,一个元素的值也是它的标识(值本身就是关键字,类型为T),并且每个值必须是唯一的。一旦在容器中,集合中的元素的值就不能被修改(元素总是不变的),但是它们可以被插入或从容器中移除。

在内部,set中的元素总是按照其内部比较对象(Compare类型)所指示的特定的严格的弱排序标准进行排序。

set容器通常比unordered_set容器通过键来访问单个元素要慢一些,但是它们允许根据子集的顺序来直接迭代。

set通常被实现为二叉搜索树。

使用set类型要包含set头文件;set定义在命名空间std中。

1. 构造、析构和赋值运算符重载

1.1 构造函数

重载函数功能
empty构造空的set类对象
range用迭代器区间[first,last)中的元素构造

copy

构造一个x的拷贝
move移动构造函数
initializer list用初始化列表来构造
#include <iostream>
#include <set>
using namespace std;

int main()
{
	set<int> s1;//empty
	for (auto e : s1)
	{
		cout << e << " ";
	}
	cout << endl;
	//空

	int arr[10] = { 4,2,2,9,6,6,6,1,7,10 };
	set<int> s2(arr, arr + 10);//range
	for (auto e : s2)
	{
		cout << e << " ";
	}
	cout << endl;
	//1 2 4 6 7 9 10

	set<int> s3(s2);//copy
	//等价于set<int> s3 = s2;
	for (auto e : s3)
	{
		cout << e << " ";
	}
	cout << endl;
	//1 2 4 6 7 9 10

	set<string> s4{ "happy","new","year","hello","world" };//initializer list
	//等价于set<string> s4 = { "happy","new","year","hello","world" };
	for (auto e : s4)
	{
		cout << e << " ";
	}
	cout << endl;
	//happy hello new world year

	return 0;
}

1.2 析构函数

1.3 赋值运算符重载

2. 迭代器

函数功能

begin

&

end

begin返回一个迭代器,指向set对象的第一个元素

end返回一个迭代器,指向set对象的最后一个元素的下一个位置

rbegin

&

rend

rbegin返回一个反向迭代器,指向set对象的最后一个元素

rend返回一个反向迭代器,指向set对象的第一个元素的上一个位置

cbegin

&

cend

cbegin返回一个const迭代器,指向set对象的第一个元素

cend返回一个const迭代器,指向set对象的最后一个元素的下一个位置

crbegin

&

crend

crbegin返回一个const反向迭代器,指向set对象的最后一个元素

crend返回一个const反向迭代器,指向set对象的第一个元素的上一个位置

begin&end和rbegin&rend返回的迭代器指向:

const_iterator是一个指向const内容的迭代器。迭代器本身可以修改,但是它不能被用来修改它所指向的内容。

begin&end/rbegin&rend和cbegin&cend/crbegin&crend的不同:

  • begin&end/rbegin&rend的返回类型由对象是否是常量来决定。如果不是常量,返回iterator;如果是常量,返回const_iterator。
  • cbegin&cend/crbegin&crend的返回类型是const_iterator,不管对象本身是否是常量。

但是set的迭代器是const的!!!虽然set类型同时定义了iterator和const_iterator类型,但两种类型都只允许只读访问set中的元素。

#include <iostream>
#include <set>
using namespace std;

int main()
{
	int arr[10] = { 4,2,2,9,6,6,6,1,7,10 };
	set<int> s(arr, arr + 10);
	
	set<int>::iterator it = s.begin();
	while (it != s.end())
	{
		cout << *it << " ";
		++it;
	}
	cout << endl;
	//1 2 4 6 7 9 10

	auto rit = s.rbegin();
	//list<int>::reverse_iterator rit = lt.rbegin();
	while (rit != s.rend())
	{
		cout << *rit << " ";
		++rit;
	}
	cout << endl;
	//10 9 7 6 4 2 1

	return 0;
}

3. 容量

函数功能
empty检测set是否为空,是返回true,否则返回false
size

返回set的元素个数

max_size返回set所能容纳的最大元素数
#include <iostream>
#include <set>
using namespace std;

int main()
{
	int arr[10] = { 4,2,2,9,6,6,6,1,7,10 };
	set<int> s(arr, arr + 10);//1 2 4 6 7 9 10
	
	if (s.empty())
		cout << "set为空" << endl;
	else
		cout << "set不为空" << endl;
	//set不为空

	cout << s.size() << endl;//7

	cout << s.max_size() << endl;//214748364

	return 0;
}

4. 修改器

函数功能
insert插入元素
erase删除元素
swap交换内容
clear清空内容
emplace构建和插入元素
emplace_hint构建和插入带有提示的元素
#include <iostream>
#include <set>
using namespace std;

int main()
{
	int arr[10] = { 4,2,2,9,6,6,6,1,7,10 };
	set<int> s1(arr, arr + 10);//1 2 4 6 7 9 10

	s1.insert(5);
	s1.insert(0);
	for (auto e : s1)
	{
		cout << e << " ";
	}
	cout << endl;
	//0 1 2 4 5 6 7 9 10

	s1.erase(--s1.end());
	s1.erase(4);
	for (auto e : s1)
	{
		cout << e << " ";
	}
	cout << endl;
	//0 1 2 5 6 7 9

	set<int> s2{ 7,3,6,8,1 };
	s1.swap(s2);
	for (auto e : s1)
	{
		cout << e << " ";
	}
	cout << endl;
	//1 3 6 7 8
	
	s1.clear();
	if (s1.empty())
		cout << "s1被清空" << endl;
	else
		cout << "s1没被清空" << endl;
	//s1被清空

	return 0;
}

5. 观察者

函数功能
key_comp返回比较对象
value_comp返回比较对象

6. 操作

函数功能
find获取元素的迭代器
count

计算特定元素的数量

返回值0或1

lower_bound返回指向下限的迭代器
upper_bound返回指向上限的迭代器
equal_range

获取相等元素的范围

范围内只有一个元素

#include <iostream>
#include <set>
using namespace std;

int main()
{
	int arr[10] = { 4,2,2,9,6,6,6,1,7,10 };
	set<int> s(arr, arr + 10);//1 2 4 6 7 9 10

	auto it = s.find(2);
	if (it != s.end())
	{
		cout << "2在set中" << endl;
	}
	else
	{
		cout << "2不在set中" << endl;
	}
	//2在set中

	it = s.find(3);
	if (it != s.end())
	{
		cout << "3在set中" << endl;
	}
	else
	{
		cout << "3不在set中" << endl;
	}
	//3不在set中

	if (s.count(7))
	{
		cout << "7在set中" << endl;
	}
	else
	{
		cout << "7不在set中" << endl;
	}
	//7在set中

	if (s.count(5))
	{
		cout << "5在set中" << endl;
	}
	else
	{
		cout << "5不在set中" << endl;
	}
	//5不在set中

	return 0;
}

7. 分配器

函数功能
get_allocator获取分配器

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/456786.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

插装式两位两通电磁阀DSV-080-2NCP、DDSV-080-2NCP

特性 压力4000 PSI(276 Bar) 持续的电磁。 硬化处理的提升阀和柱塞可获得更长的寿命和低泄漏量。 有效的混式电磁铁结构。 插装阀允许交流电压。可选的线圈电压和端子。 标准的滤网低泄漏量选择 手动关闭选择。 工业化通用阀腔。 紧凑的尺寸。 两位两通常闭式双向电磁…

热门好用的企业网盘工具大盘点

企业网盘作为热门的企业文件管理工具相比于个人网盘&#xff0c;更注重安全性&#xff0c;并增加了协同功能。当下市面上的企业网盘工具可谓是百花齐放&#xff0c;今天就盘点几款热门好用的网盘工具&#xff0c;希望能帮助您挑选到心仪的网盘工具~ 1. Zoho Workdrive Zoho Wo…

#PythonPytorch 2.如何对CTG特征数据建模

系列文章目录 #Python&Pytorch 1.如何入门深度学习模型 #Python&Pytorch 2.如何对CTG特征数据建模 我之前也写过一篇使用GBDT对UCI-CTG特征数据进行建模的博客&#xff0c;不过那是挺早的时候写的&#xff0c;只是简单贴了代码&#xff0c;方便了解流程而已&#xff0…

原神3.2剧情服搭建教程

同步官服所有剧情和交互 优化后电脑16G运行内存也可以完美运行 数据库再次启动报错的,把将redis.service中的Type=forking配置删除或者注释掉即可。 位于:/usrb/systemd/system/redis.service 然后重启服务就不会爆错了。 下面是具体步骤 su root (此处会提示输入密…

相机雷达联合标定cam_lidar_calibration

文章目录 运行环境&#xff1a;1.1 ROS环境配置1&#xff09;工作空间创建和编译2&#xff09;官方数据集测试环境 2.1 在线标定1&#xff09;数据类型2&#xff09;标定板制作3&#xff09;配置文件4&#xff09;开始标定5&#xff09;完整实现步骤 3.1 python版本选择3.2 rvi…

医疗保障信息平台HASF应用系统技术架构名词解释技术选型架构图

下载地址&#xff1a; 医疗保障信息平台HASF应用系统技术架构规范.pdf下载—无极低码 HSAF 医疗保障应用框架&#xff08;Healthcare Security Application Framework&#xff09; IaaS 基础设施即服务&#xff08;Infrastructure-as-a-Service&#xff09; PaaS 平台即服务…

实现了单链表各种功能,并配上详细解读。

单链表 链表的概念及结构链表的分类链表的实现初始化打印申请结点头插尾插头删尾删查找在pos位置之后插入在pos位置之前插入删除pos位置之后的值删除pos位置的值销毁 链表的概念及结构 概念&#xff1a;链表是一种物理存储结构上非连续、非顺序的存储结构&#xff0c;数据元素…

离散数学期末复习第一章 数理逻辑

离散数学 离散数学是研究各种各样的离散量的结构及离散量之间的关系一门学科&#xff0c;是计算机科学中基础理论的核心课程。 什么是连续变量&#xff1f; 在一定区间内可以任意取值的变量叫连续变量&#xff0c;其数值是连续不断的&#xff0c;相邻两个数值可作无限分割&a…

buuctf4

目录 [极客大挑战 2019]LoveSQL [极客大挑战 2019]Http [极客大挑战 2019]Knife qr 镜子里面的世界 ningen 小明的保险箱 爱因斯坦 easycap 隐藏的钥匙 另外一个世界 FLAG [极客大挑战 2019]LoveSQL 1.启动环境&#xff0c; 使用万能密码尝试一下 2.跳转到了check.php…

维度云工业品ERP进销存软件教您如何突破工业品生意的困境?

是困境也是机遇 随着全球化和技术进步的不断推进&#xff0c;工业品贸易正逐渐成为国际贸易的重要组成部分。工业品包含了从原材料、零部件到工业设备、机械以及其他工业用品等范畴的产品&#xff0c;涉及各种制造、加工和组装过程。在全球供应链互联互通之下&#xff0c;工业品…

【人工智能概论】 用Python实现数据的归一化

【人工智能概论】 用Python实现数据的归一化 文章目录 【人工智能概论】 用Python实现数据的归一化一. 数据归一化处理的意义二. 常见的归一化方法2.1 最大最小标准化&#xff08;Min-Max Normalization&#xff09;2.2 z-score 标准化 三. 用sklearn实现归一化 一. 数据归一化…

服务(第十一篇)LVS

什么是群集&#xff1f; 多台主机组成的一个整体&#xff0c;提供一个ip访问通道&#xff0c;所有的主机干一件事 提供同样的服务。 群集有哪些类型&#xff1f; ①负载均衡群集&#xff08;LB&#xff09;&#xff1a; 提高系统的响应能力&#xff0c;处理更多的访问请求&a…

20、Theos越狱调试Wallet

前面的总结中使用砸壳重签后的App进行调试,本篇在越狱环境下不重签App进行调试,但是还是需要砸壳获取Headers. 一、Cycript 1.1 在越狱环境中使用Cycript 在越狱环境上,安装Cycript插件.需要先安装adv-cmds插件,因为被Cycript插件所依赖、在Cydia中,安装Cycript 在设备中找到…

观察者设计模式(Observer Design Pattern)[论点:概念、组成角色、相关图示、示例代码、框架中的运用、适用场景]

文章目录 概念组成角色相关图示示例代码框架中的运用适用场景 概念 观察者设计模式&#xff08;Observer Design Pattern&#xff09;是一种行为型设计模式&#xff0c;它定义了一种对象间的一对多的依赖关系&#xff0c;让多个观察者对象同时监听某一个主题对象&#xff0c;当…

LLaMA模型文件 (搬运工)

LLaMA需要进行申请才能获得官方模型权重。 但是申请的审批时间一般都很长。 这里提供现有的huggingface上&#xff0c;第三方上传的一些LLaMA模型文件&#xff1a; LLaMA-7BLLaMA-13BLLaMA-7B-hfLLaMA-13B-hf 这里要注意&#xff0c;原始的LLaMA权重文件&#xff0c;是不能…

【Java面试八股文】SSM,SpringBoot篇

引言&#xff1a; 本文对多个平台的面试题进行了汇总、分类、概括、整理&#xff0c;对重点进行了标出&#xff0c;更便于阅读和记忆。 【黑马Java笔记踩坑汇总】JavaSEJavaWebSSMSpringBoot瑞吉外卖SpringCloud黑马旅游谷粒商城学成在线牛客面试题 目录 Spring 简单介绍Spri…

ubuntu 20.04 安装obs 录屏软件

obs是一个非常好用的录屏软件&#xff0c;我们在windows安装和使用是非常的简单&#xff0c;但是在ubuntu安装还是比较麻烦的&#xff0c;需要使用命令行&#xff0c;还需要很多的依赖。 修改源 deb http://archive.ubuntu.com/ubuntu/ focal main restricted universe multi…

大白话告诉你!前端是怎么回事儿?

假期回家&#xff0c;学会计的表弟化身十万个为什么的问我&#xff01; 你们前端到底是干什么的&#xff1f;为什么我的同学好多转行去做这个的&#xff1f;你们前端程序员真的这么赚钱么&#xff1f;你也别跟我说什么敲代码的&#xff0c;你告诉我&#xff0c;你敲得这是什么代…

Linux网络——部署YUM仓库

Linux网络——部署YUM仓库 一、YUM仓库服务1.准备安装源&#xff1a;①.软件仓库的提供方式②.RPM软件包的来源③.构建CentOS7软件仓库④.在软件仓库中加入非官方RPM包组⑤.访问yum仓库 2.yum下载软件包的方式①..开启缓存下载②.通过yum命令的选项下载③.通过yumdownloader命令…

容器化实战--vmware安装centos7-安装docker-idea部署springBoot项目到docker

前言 走过的坑终将化为蒲公英&#xff0c;风一吹就消散了&#xff0c;然后继续掉坑… 整体背景 win10 idea2019.3 vmware15 pro CentOS-7-x86_64-DVD-2009.iso docker 23.0.4 redis mysql8 springBoot项目 1.安装虚拟软件vmware15 pro 安装vmware15 2.安装宿主机centos7 …