《算法笔记》6.2 set详解

6.2 set详解

set翻译为集合,是一个内部自动有序 不含重复元素 的容器。
如果使用set,需添加头文件和命名空间。

#include<set>
using namespace std ;

1. 单独定义set

set<typename> name ;

基本定义与vector基本一样。

2.set容器内元素访问

set只能通过迭代器访问:

set<typename>::iteartor it  ;

for( auto it = st.begin() ; it != st.end() ; it++ ){
	cout << *it << endl ;
}

3.set常用函数

(1)insert()

insert(x)可将x插入set容器,并自动排序去重,时间复杂度为O(logN)。

(2)find()

find(value)返回set中对应值的迭代器,时间复杂度为O(logN)。

auto it = st.find(3) ;

若没有找到则返回st.end(),即若st中没有3,则it=st.end()。

(3)earse()

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

  1. 删除单个元素
  • erase(it),it即为所需要删除元素的迭代器。时间复杂度为O(1)。
st.erase( st.find(100) ) ;
  • st.erase(value),value为所需要删除的值。时间复杂度为O(logN)。
  1. 删除一个区间内所有元素
    st.erase(first , last),注意[first , last)

(4)size()

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

(5)clear()

clear()用来清空set中的所有元素,复杂度为O(N)

4. set的常见用途

set最主要的最用是自动去重并按升序排序。
延伸:set中元素是唯一的,如果需要处理不唯一的情况,则需要使用multiset。另外,C++11标准中还增加了unordered_set,以散列代替set内部的红黑树实现,使其可以用来处理只去重不排序的需求。速度比set快得多。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值