• set集合容器底层由红黑树实现,是平衡二叉搜索树。
  • 相对stl中的list、deque效率更高。
  • 注意:由于集合 的 性质,单纯的 set 不允许重复的元素
  • 初始化 / 清空 函数 : clear()
  • 插入 / 添加 函数:insert(x) (插入键值x到集合中)
  • 插入 / 添加 函数:insert(iterator,iterator) (插入迭代器之间的元素到集合中)
  • 检索 / 查找 函数:find(x) (查找键值为x的元素,若存在,则返回键值的迭代器位置,否则返回集合最后一个元素的下一个位置)
  • 删除 函数:erase(x) (删除键值为x的元素)
  • 删除 函数:erase(iterator) (删除迭代器位置的元素)
  • 删除 函数:erase(iterator,iterator) (删除迭代器之间的值)
  • 累计 函数:count(x)(用来查找集合中某个元素是否出现过,只返回1或0)
  • 类似二分查找 函数:equal_range(x)(返回第一个大于或等于键值的迭代器 和 第一个大于键值的迭代器)
#include <set>
#include <iterator>
#include <iostream>
#include <algorithm> using namespace std; typedef set<int> S;
S s;
int n; int main()
{
cin>> n;
for( int i = 0 ; i < n ; i++ ){
int x;
cin>> x;
s.insert( x );
}
pair< S::const_iterator,S::const_iterator > pr;
int y;
cin>> y;
pr = s.equal_range( y );
cout<< *pr.first << *pr.second <<endl;
return 0;
}

怎样更加灵活地使用set?

》》》
1.灵活使用关键字排序
※若集合元素不是结构体是单纯的变量类型,用结构体重载()运算符
#include <set>
#include <vector>
#include <iterator>
#include <iostream>
#include <algorithm> using namespace std; struct cmp{
bool operator () ( const int &a,const int &b ){
return a>b;
}
};
typedef set<int,cmp> S;
int n;
S s; int main()
{
cin>> n;
for( int i = 0 ; i < n ; i++ ){
int x;
cin>> x;
s.insert( x );
}
for( S::iterator i = s.begin() ; i != s.end() ; i++ )
cout<< *i <<endl;
return 0;
}

※若集合元素为结构体,直接在元素结构体内重载 < 运算符即可

2.灵活使用遍历
※顺序遍历,使用iterator直接遍历即可
set<int> s ;
for( set<int>::iterator i = s.begin() ; i != s.end() ; i++ );

※反序遍历,使用reverse_iterator

set<int> s ;
for( set<int>::reverse_iterator i = s.rbegin() ; i != s.rend() ; i++ )
  • set的遍历是高效的中序遍历,也就是说iterator的++和--就可以直接得到其前驱和后继

stl学习(二)集合 set 的使用的更多相关文章

  1. STL学习二:Vector容器

    1.Vector容器简介 vector是将元素置于一个动态数组中加以管理的容器. vector可以随机存取元素(支持索引值直接存取, 用[]操作符或at()方法,这个等下会详讲). vector尾部添 ...

  2. 侯捷STL学习(二)

    第六节:容器之分类和各种测试(四) stack不提供iterator操作,破坏了容器的独特性,先进先出. 使用容器multiset(允许元素重复) 内部是红黑树,insert操作就保证了排好了序. 标 ...

  3. 侯捷STL学习(二)--序列容器测试

    第六节:容器之分类和各种测试(四) stack不提供iterator操作,破坏了容器的独特性,先进先出. 使用容器multiset(允许元素重复) 内部是红黑树,insert操作就保证了排好了序. 标 ...

  4. ###STL学习--关联容器

    点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的关联容器. ###stl学习 |--迭 ...

  5. ###STL学习--适配器

    点击查看Evernote原文. #@author: gr #@date: 2014-08-24 #@email: forgerui@gmail.com STL中的适配器. ###stl学习 |--迭代 ...

  6. STL学习:STL库vector、string、set、map用法

    本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...

  7. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  8. ###STL学习--vector

    点击查看Evernote原文. #@author: gr #@date: 2014-08-11 #@email: forgerui@gmail.com vector的相关问题.<stl学习> ...

  9. ###STL学习--迭代器

    点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的迭代器. ###stl学习 |--迭代 ...

  10. ###STL学习--函数对象

    点击查看Evernote原文. #@author: gr #@date: 2014-08-13 #@email: forgerui@gmail.com 在stl中,函数对象被大量地使用,用以提高代码的 ...

随机推荐

  1. AFNetwork2.0在报错1016,3840的解决方法及一些感悟

    最近在学习AFNetwork,非常好的网络框架,能节省很多时间.不过请求网络数据时报错1016,3840. 这两个错误网上解决方法很多,http://blog.csdn.net/huifeidexin ...

  2. 【代码笔记】iOS-清除图片缓存UIActionSheet

    一,效果图. 二,代码. RootViewController.m //点击任何处出现sheet -(void)touchesBegan:(NSSet *)touches withEvent:(UIE ...

  3. 【Andorid】短视频拍摄SDK——Vitamio Recorder 2.0 发布(支持ffmpeg命令行)

    简介 VCamera SDK Android 版(短视频拍摄SDK)是炫一下(北京)科技有限公司推出的软件开发工具包,为Android开发者提供简单.快捷的接口,帮助开发者实现Android平台上的短 ...

  4. flashdevelop生成swc库

    flashdevelop没有直接支持生成swc的工程,但flashdevelop生成swc也比较方便,不用任何插件. swc库是由 flexsdk的compc.exe生成的,其实我们通过这个命令行也可 ...

  5. 结对编程-地铁续(有种上个学期OO的既视感)

    我们组比较特殊..三人结对 github:https://github.com/qingchanghan/WPFUI_Metro po一张照片: 石浩然,韩青长.陈彦吉 (台式机真的很高端,分屏贼帅) ...

  6. 5个示例带你学习AngularJS

    直到现在,你或许已经听说过AngularJS了,一个改变你对web应用思考方式,由谷歌开发的令人兴奋的开源框架.关于它的文章已经写得非常之多,但我发现还是要写些给那些更喜欢快速且实际例子的开发者.当今 ...

  7. Redis简介

    Redis是一个偏重于in-memory的key-value数据库,这样讲有点儿不准确,但是很容易将Redis简单分类.更准确的讲Redis是一个数据结构的存储服务.它的value不仅仅只有strin ...

  8. Oracle shutdown immediate遭遇ORA-24324 ORA-24323 ORA-01089

    一数据库服务器执行shutdown immediate时,遇到了下面ORA错误,如下所示: $ sqlplus / as sysdba   SQL*Plus: Release 10.2.0.4.0 - ...

  9. SQL Server 2012中Task是如何调度的?

    SQL Server 2012中Task是如何调度的?[原文来自:How It Works: SQL Server 2012 Database Engine Task Scheduling]     ...

  10. Oracle Latch的学习【原创】

    Latch详解 - MaxChou 本文以学习为目的,大部分内容来自网络转载. 什么是Latch 串行化 数据库系统本身是一个多用户并发处理系统,在同一个时间点上,可能会有多个用户同时操作数据库.多个 ...