C++ STL set用法详解

本文详细介绍了C++ STL中的set数据结构,包括创建、初始化、特性和元素遍历。讲解了set的插入、清除、查找、删除、计数、大小判断、空状态检查以及范围查找等基本函数的使用方法,并提供了相应的代码示例。
摘要由CSDN通过智能技术生成

目录

1.set的创建。

具体例子:

set初始化:

2.set的特性。

3.set元素遍历:

迭代器创建:

4.set的基本函数。

4.1.insert()

4.2  clear()

4.3 find()

4.4 erase()

4.5  count()

4.6  size()

4.7 empty

4.8 lower_bound()

4.9 upper_bound()

附录:

1.迭代器:


我们都知道,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底层的实

  • 30
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值