STL--集合:set

目录

set的定义

set容器内元素的访问

set常用函数实例解析

set的常见用途

set的定义

set是一个内部自动有序且不含重复元素的容器。在做题过程中有可能出现需要去掉重复元素的情况,而且有可能因这些元素比较大或者类型不是int型而不能直接开散列表,在这种情况下就可以用set来保留元素本身而不考虑它的个数。当然,上面说的情况也可以通过再开一个数组进行下标和元素的对应来解决。但是set提供了更为直观的接口,并且加入set之后可以实现自动排序。

单独定义一个set:

set<typename> name;

其定义的写法其实和vector基本是一样的,或者说其实大部分STL都是这样定义的。这里的typename依然可以是任何基本类型,例如:int、double、char、结构体等,或者是STL标准容器,例如vector、set、queue等。

和前面vector中提到的一样,如果typename是一个STL容器,那么定义时要记得在>>符号之间加上空格。

set容器内元素的访问

set只能通过迭代器访问

set<typename>::iterator it;

这样就得到了迭代器it,并且可以通过*it来访问set里的元素。

由于除开vector和string之外的STL容器都不支持*(it+i)的访问方式,因此只能按如下方式枚举:

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	st.insert(3);
	st.insert(4);
	st.insert(2);
	st.insert(3);
	for(set<int>::iterator it=st.begin();it!=st.end();it++){
		printf("%d ",*it);
	}
	return 0;
}

输出结果

2 3 4

可以发现,set内的元素自动递增排序,且自动去除了重复元素

set常用函数实例解析

(1)insert()

insert(x)可将x插入set容器中,并自动递增排序和去重,时间复杂度为O\left ( logN \right ),其中N为set内的元素个数。

(2)find()

find(value)返回set中对应值为value的迭代器,时间复杂度为O\left ( logN \right ),N为set内的元素个数。

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	for(int i=5;i<=9;i++){
		st.insert(i);
	}
	set<int>::iterator it=st.find(6);
	printf("%d\n",*it);
	return 0;
}

输出结果

6

(3)erase()

erase()有两种用法:删除单个元素 、删除一个区间内的所有元素

1.删除单个元素

删除单个元素有两种方法:

st.rease(it),it为所需要删除元素的迭代器,时间复杂度为O\left ( 1 \right )。可以结合find()函数来使用。

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	st.insert(100);
	st.insert(200);
	st.insert(300);
	st.insert(100);
	st.erase(st.find(300));
	st.erase(st.find(200));
	for(set<int>::iterator it=st.begin();it!=st.end();it++){
		printf("%d\n",*it);
    }
    return 0;
}

输出结果

100

st.erase(value),value为需要删除元素的值。时间复杂度为O\left ( logN \right ),N为set内的元素个数。

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	st.insert(100);
	st.insert(200);
	st.erase(100);
	for(set<int>::iterator it=st.begin();it!=st.end();it++){
		printf("%d\n",*it);
	}
	return 0;
} 

输出结果

200

2.删除一个区间内的元素

st.erase(first,last)可以删除一个区间内的所有元素,其中first为所需要删除区间的起始迭代器,而last则为所需要删除区间的末尾迭代器的下一个地址,也即为删除[first,last)。时间复杂度为O\left ( last-first \right )

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	st.insert(20);
	st.insert(10);
	st.insert(40);
	st.insert(30);
	set<int>::iterator it=st.find(30);
	st.erase(it,st.end());
	for(it=st.begin();it!=st.end();it++){
		printf("%d ",*it);
	}
	return 0;
}

输出结果

10 20

(4)size()

size()用来获得set内元素的个数,时间复杂度为O\left ( 1 \right )

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	st.insert(2);
	st.insert(5);
	st.insert(4);
	printf("%d\n",st.size());
	return 0;
}

(5)clear()

clear()用来清空set中的所有元素,复杂度为O\left ( N \right ),其中N为set内元素的个数

#include<stdio.h>
#include<set>
using namespace std;
int main(){
	set<int> st;
	st.insert(2);
	st.insert(5);
	st.insert(4);
	st.clear();
	printf("%d\n",st.size());
	return 0;
}

set的常见用途

set最主要的作用是自动去重并升序排列,因此碰到需要去重但是却不方便直接开数组的情况,可以尝试使用set解决。

  • 18
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

互联网的猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值