首页 > 其他 > 详细

set用法

时间:2018-03-02 20:19:58      阅读:202      评论:0      收藏:0      [点我收藏+]

1.

关于set,必须说明的是set关联式容器。

在set中每个元素的值都唯一,而且系统能根据元素的值自动进行排序。

应该注意的是set中数元素的值不能直接被改变。

 

2.set中常用的方法


begin()        返回set容器的第一个元素

end()      返回set容器的最后一个元素

clear()          删除set容器中的所有的元素

empty()    判断set容器是否为空

max_size()   返回set容器可能包含的元素最大个数

size()      返回当前set容器中的元素个数

rbegin     返回的值和end()相同

rend()     返回的值和rbegin()相同

 

注意begin() 和 end()函数是不检查set是否为空的,使用前最好使用empty()检验一下set是否为空.

3.

count() 用来查找set中某个某个键值出现的次数。

这个函数在set并不是很实用,因为一个键值在set只可能出现0或1次,这样就变成了判断某一键值是否在set出现过了。

 

find()  ,返回给定值值得定位器,如果没找到则返回end()。

 

insert(key_value); 将key_value插入到set中

返回值是 pair<set<int>::iterator,bool>,bool标志着插入是否成功,

而iterator代表插入的位置,若key_value已经在set中,则iterator表示的key_value在set中的位置。

 

inset(first,second);将定位器first到second之间的元素插入到set中,返回值是void.

 

lower_bound(key_value) ,返回第一个大于等于key_value的定位器

upper_bound(key_value),返回第一个大于key_value的定位器

 

4.

erase(iterator)  ,删除定位器iterator指向的值

erase(first,second),删除定位器first和second之间的值

erase(key_value),删除键值key_value的值

set中的删除操作是不进行任何的错误检查的,比如定位器的是否合法等等,所以用的时候自己一定要注意。

 

5.自定义比较函数

如果元素是结构体,可以直接将比较函数写在结构体内。

 1         struct Info
 2         {
 3             string name;
 4             float score;
 5             //重载“<”操作符,自定义排序规则
 6             bool operator < (const Info &a) const
 7             {
 8                 //按score从大到小排列
 9                 return a.score<score;
10             }
11         }
12         set<Info> s;
13         ......
14         set<Info>::iterator it;

 

set用法

原文:https://www.cnblogs.com/adelalove/p/8494700.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!