STL之set、multiset、functor&pair使用方法

set是一个集合容器,其中包含的元素是唯一的,集合中的元素是按照一定的顺序排列的。元素插入过程是按照排序规则插入,所以不能使用指定位置插入。

set采用红黑树变体的数据结构实现,红黑树属于平衡二叉树。在插入操作和删除操作上比vector快。

set不可以直接存取元素,(不可以使用at.(pos)与[]操作符

multiset与set的区别:set支持唯一键值,每个元素都只能出现一次,而multiset中同一值可以出现多次。

不可以直接修改set或multiset容器中的元素值,因为该类容器是自动排序的,如果希望修改成同一元素值必须先删除原有的元素,再插入新的元素。

关于set怎样使一个我们自己定义的类型达到我们规定的排序目的呢?

假如定义一个CStudent类怎么样让这个类的元素按照学号来排序呢?

首先我们先来定义这样一个类然后利用set排序就是对operator()进行的重载来比较大小,就自己将这个方法写入到一个结构体中调用它,具体过程如下

STL之set、multiset、functor&pair使用方法
 1 class CStudent
 2 {
 3 public:
 4     int m_n_ID;
 5     string m_strName; 
 6     CStudent(int iID, string strName)
 7     {
 8         m_n_ID = iID;
 9         m_strName = strName;
10     }
11 };
12 
13 struct studentFounction 
14 {
15     bool operator()(const CStudent &stu1,const CStudent &stu2)
16     {
17         return (stu1.m_n_ID<stu2.m_n_ID);
18     }
19 
20 };
21 
22 set<CStudent,studentFounction> setStu;
23 setStu.insert(CStudent(1,"小王"));
24 setStu.insert(CStudent(3,"小刘"));
25 setStu.insert(CStudent(6,"小李"));
26 setStu.insert(CStudent(2,"小张"));
27 setStu.insert(CStudent(4,"小彭"));
28 setStu.insert(CStudent(5,"小杰"));
29 for (set<CStudent,studentFounction>::iterator it = setStu.begin();it != setStu.end();it++)
30 {
31     cout<<it->m_strName<<endl;
32 }
STL之set、multiset、functor&pair使用方法

 值得一说的是在删除中set.erase(elem)//根据元素值删除对应元素

 

set<int>::iterator it = setInt.find(elem)//返回查找值对应迭代器

set<int>::iterator it = setInt.lower_bound(elem);//返回的是第一个比指定值小的元素迭代器

set.equal_range(elem);//返回容器中与elem相等的上下限的两个迭代器。

而需要注意的是下限是开区间上限是闭区间[beg,end).以上函数返回两个迭代器,而这两个迭代器被封装在pair中。

pair被译为对组,可以将恋歌视为一个单元。pari<T1,T2>存放的两个值的类型,可以不一样,如T1为int,T2为float。T1,T2也可以是自定义类型

pair.first是pair里面的第一个值,是T1的类型

pair.second是pair里面的第二个值,是T2的类型

multiset可以有相同的元素这是与set的不同之处

STL之set、multiset、functor&pair使用方法

上一篇:QTableView得到当前选择的列


下一篇:squid添加用户名密码认证