c++:STL(set)

既上篇,这篇继续讲述set。

set:

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

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

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

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

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

(6)set 默认构造对象:

         如:set<int> setInt;            //一个存放int的set容器。

(7)set的相关用法

set.insert(elem);                          //在容器中插入元素。
set.begin();                                  //返回容器中第一个数据的迭代器。
set.end();                                     //返回容器中最后一个数据之后的迭代器。
set.rbegin();                                //返回容器中倒数第一个元素的迭代器。
set.rend();                                   //返回容器中倒数最后一个元素的后面的迭代器。

set<int,less<int> >  setIntA;                    //该容器是按升序方式排列元素。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值