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()有两种用法:删除单个元素、删除一个区间的元素。
- 删除单个元素
- erase(it),it即为所需要删除元素的迭代器。时间复杂度为O(1)。
st.erase( st.find(100) ) ;
- st.erase(value),value为所需要删除的值。时间复杂度为O(logN)。
- 删除一个区间内所有元素
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快得多。