C++ STL set用法详解

我们都知道,set是STL里的一种数据结构,这篇博客就是set用法的详解。

1.set的创建。

set初始化一般是

set<数据结构名称> 名字;

具体例子:

创建一个int型,名称是s的set。

set<int> s;

set还可以创建STL里的数据结构(包括自己)

set<pair<int,int>> s;set<set<int>> s;

set初始化:

再创建时,可以对set进行初始化。

set<int> s={1,3,6,4};

这样就给s的初始化成{1,3,6,4} 

2.set的特性。

set特性有两点:

  1. 会自动排序。
  2. 会自动去重。
  3. 底层使用红黑树实现

3.set元素遍历:

set不能用下标访问,只能用迭代器访问。

迭代器创建:

例如创造set<int> 的迭代器:

set<int>::iterator it;

这样就成功的创建了set<int> 的迭代器,名子是it。 

遍历set<int> s;的所有元素:

for(it=s.begin();it!=s.end();it++)
{}

用*it来访问当前的元素。

示例:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,4};set<int>::iterator it;for(it=s.begin();it!=s.end();it++){cout<<*it<<' ';}return 0;
}

结果如下:

如果你很懒,那么还有一种方式很适合你:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,4};for(auto it:s){cout<<it;}return 0;
}

注意:这里是用it,不是*it。

结果如下 :

当题目卡常时:不建议用auto,用迭代器。 

4.set的基本函数。

这里会讲:insert(),clear(),find(),erase(),count(),size(),empty(),lower_bound(),upper_bound()。

4.1.insert()

先来看一下STL底层的实现。

看不懂没关系,那不是重点。

s.insert(x)代表再s的末尾添加一个x。

复杂度:O(\log_2^N) 

示例代码:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,4};s.insert(9);for(auto it:s){cout<<it;}return 0;
}

结果:

注:insert有很多种形式,由于博主太菜,不会,就分享这一种。

4.2  clear()

老规矩,底层实现:

这个函数用法很简单:清空一个set的所有元素。

s.clear()清空s里所有元素。

示例:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,4};s.insert(9);printf("s清空前:\n");for(auto it:s){printf("%d ",it);}printf("\n");s.clear();printf("s清空后:\n");for(auto it:s){printf("%d ",it);}return 0;
}

执行结果:

由图发现,清空后s啥都没有了。

复杂度:O(N)N为元素个数。

4.3 find()

这个函数不太推荐使用,可以用之后的count更方便。

底层实现:

find(x) 如果找到了,返回迭代器,找不到返回s.end()

也可以这么理解:find(x) 找到了返回x的迭代器,找不到返回数组元素个数迭代器

具体用法:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,4};s.insert(9);//此时s = {1,2,3,4,9};//找到:set<int>::iterator it = s.find(9);cout<<"找到了:"<<*it<<'\n';//找不到:it = s.find(222);cout<<"没找到:"<<*it;return 0;
}

运行结果:

可以和if else 配合:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,4};s.insert(9);//此时s = {1,2,3,4,9};if(s.find(5)==s.end()){cout<<"没找到";}else{cout<<"找到了";}return 0;
}

复杂度:O(\log_2^N) 

4.4 erase()

底层实现:

s.erase(x)是从s种删除x这个元素。

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,5};//原来sprintf("原来的s:\n");for(auto it:s){cout<<it<<' ';}printf("\n");s.erase(3);//删除printf("删除3后的s:\n");for(auto it:s){cout<<it<<' ';}return 0;
}

结果如下:

复杂度:O(N)

4.5  count()

这个函数可以代替find函数。

底层实现:

count(x) 可以返回set中x元素出现的次数,由于set自动去重,所以只返回(0/1)

有出现:1

没出现:0

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,6};//此时s = {1,2,3,6};if(s.count(4) == 0){cout<<"没找到";}else{cout<<"找到了";}return 0;
}

4没有出现,是没找到。

 复杂度:O(1)

4.6  size()

这个...不需多讲,就是返回set中元素个数。

底层实现:

具体用法:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,6};//此时s = {1,2,3,6};cout<<s.size();return 0;
}

复杂度:O(1) 

4.7 empty

这个比size还简单,如果set非空,那么返回0,否则返回1。

底层实现:

复杂度:O(1) 

4.8 lower_bound()

lower_bound(x)

这个是找到set中第一个>=x的迭代器。不存在则返回end()

底层实现:

代码示例:

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,6};//此时s = {1,2,3,6};set<int>::iterator it = s.lower_bound(4);cout<<*it;return 0;
}

第一个>=4的,是6

结果:

复杂度:O(\log_2^N)  

4.9 upper_bound()

和lower_bound()很像,但是upper_bound是返回第一个>x的迭代器,不存在则返回end()

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,6};//此时s = {1,2,3,6};set<int>::iterator it = s.upper_bound(3);cout<<*it;return 0;
}

结果:

复杂度:O(\log_2^N) 

好,函数部分到此结束。

附录:

1.迭代器:

你可以将迭代器理解成指针。

当你想反向遍历set时,要用到rbegin和rend。

#include<bits/stdc++.h>
using namespace std;
int main()
{set<int> s={1,2,3,6};//此时s = {1,2,3,6};set<int>::reverse_iterator it;//反向迭代器for(it=s.rbegin();it!=s.rend();it++)//注意啊!!!这里还是用it++{cout<<*it<<' ';}return 0;
}

结果:


set各种迭代器区别:

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入剖析ShardingSphere:探索其内核原理与核心源码,揭秘分库分表技术的奥秘

一、 内核剖析 ShardingSphere虽然有多个产品&#xff0c;但是他们的数据分片主要流程是完全一致的。 解析引擎 解析过程分为词法解析和语法解析。 词法解析器用于将SQL 拆解为不可再分的原 子符号&#xff0c;称为Token。 并根据不同数据库方言所提供的字典&#xff0c;将其…

Linux操作系统极速入门[常用指令]

linux概述&#xff1a; Linux是一套免费使用和自由传播的操作系统 我们为什么要学&#xff0c;Linux&#xff1f; 主流操作系统&#xff1a; linux系统版本&#xff1a; 内核版&#xff1a; 由linux核心团队开发&#xff0c;维护 免费&#xff0c;开源 负责控制硬件 发行版&…

瑞典最大的连锁超市Coop再遭勒索软件团伙攻击

近日&#xff0c;仙人掌勒索软件团伙声称已经黑入了瑞典最大的连锁超市Coop&#xff0c;并威胁要公开大量个人信息&#xff0c;超过2万个目录。 据了解&#xff0c;Coop在瑞典大约有800家商店&#xff0c;这些商店分属于29个消费者协会&#xff0c;拥有350万个会员&#xff0c…

drf知识-09

自定义频率类 # throttling 频率限制 # 简单方案 from rest_framework.throttling import SimpleRateThrottle class CommonThrottle(SimpleRateThrottle):rate 3/mdef get_cache_key(self, request, view):ip request.META.get(REMOTE_ADDR)return ip# 复杂方案---》通用方案…

灰度发布及声明式资源管理(yaml文件)

一、三种常见的项目发布方式 1&#xff09;蓝绿发布 2&#xff09;灰度发布【常用】 3&#xff09;滚动发布 应用程序升级&#xff0c;面临最大的问题是新旧业务之间的切换 立项-定稿-需求发布-开发-测试-发布&#xff0c;测试上线后&#xff0c;再完美也会有问题&#xff0c;为…

计算机组成原理-期末复习

第一章——计算机系统概述 一、数字计算机的主要组成结构 在电子计算机里&#xff0c;相当于算盘功能的部件&#xff0c;我们称之为运算器&#xff1b;相当于纸那样具有“记忆’功能的部件&#xff0c;我们称之为存储器&#xff1b;相当于笔那样把原始解题信息送到计算机或把…

关于简单的数据可视化

1. 安装数据可视化必要的openpyxl、pandas&#xff0c;matplotlib等软件包 使用清华源&#xff0c;命令如下&#xff1a; pip install -i https://pypi.tuna.tsinghua.edu.cn/simple --trusted-host pypi.tuna.tsinghua.edu.cn pandaspip install -i https://pypi.tuna.tsingh…

2024,全网最全的接口测试工具之postman

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

机器学习基本概念及模型简单代码(自用)

监督学习 监督学习是机器学习的一种方法&#xff0c;其中我们教导模型如何做出预测或决策&#xff0c;通过使用包含输入和对应输出的已标注数据集进行训练。这种方法的关键特点是利用这些标注数据**&#xff08;即带有正确答案的数据&#xff09;**来指导模型的学习过程。 一言…

下载和安装AD14 - Altium Designer 14.3.20.54863

这个版本应该还支持XP 系统[doge]&#xff0c;总之就是想安装一下&#xff0c;没什么特别的意义。 下载 资源来自毛子网站&#xff1a;https://rutracker.net/forum/viewtopic.php?t5140739&#xff0c;带上个网页翻译插件就行。要用磁力链接下载&#xff0c;推荐用qbittorr…

SQLSERVER排查CPU占用高

操作系统是Windows2008R2 ,数据库是SQL2008R2 64位 64G内存,16核CPU 硬件配置还是比较高的,他说服务器运行的是金蝶K3软件,数据库实例里有多个数据库 现象 他说是这几天才出现的,而且在每天的某一个时间段才会出现CPU占用高的情况 内存占用不太高,只占用了30个G CPU…

Redis——centos7环境安装Redis6.2.14版本,make命令编译时报错:jemalloc/jemalloc.h:没有那个文件或目录

一、报错原因 在redis-6.2.14文件夹下有一个README.md文件&#xff0c;有如下一段话&#xff1a; 在构建 Redis 时&#xff0c;通过设置 MALLOC 环境变量来选择非默认的内存分配器。Redis 默认编译并链接到 libc malloc&#xff0c;但在 Linux 系统上&#xff0c;jemalloc 是…