stl学习(二)集合 set 的使用
- 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?
#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;
}
※若集合元素为结构体,直接在元素结构体内重载 < 运算符即可
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 的使用的更多相关文章
- STL学习二:Vector容器
1.Vector容器简介 vector是将元素置于一个动态数组中加以管理的容器. vector可以随机存取元素(支持索引值直接存取, 用[]操作符或at()方法,这个等下会详讲). vector尾部添 ...
- 侯捷STL学习(二)
第六节:容器之分类和各种测试(四) stack不提供iterator操作,破坏了容器的独特性,先进先出. 使用容器multiset(允许元素重复) 内部是红黑树,insert操作就保证了排好了序. 标 ...
- 侯捷STL学习(二)--序列容器测试
第六节:容器之分类和各种测试(四) stack不提供iterator操作,破坏了容器的独特性,先进先出. 使用容器multiset(允许元素重复) 内部是红黑树,insert操作就保证了排好了序. 标 ...
- ###STL学习--关联容器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的关联容器. ###stl学习 |--迭 ...
- ###STL学习--适配器
点击查看Evernote原文. #@author: gr #@date: 2014-08-24 #@email: forgerui@gmail.com STL中的适配器. ###stl学习 |--迭代 ...
- STL学习:STL库vector、string、set、map用法
本文仅介绍了如何使用它们常用的方法. vector 1.可随机访问,可在尾部插入元素:2.内存自动管理:3.头文件#include <vector> 1.创建vector对象 一维: (1 ...
- 标准模板库(STL)学习探究之vector容器
标准模板库(STL)学习探究之vector容器 C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...
- ###STL学习--vector
点击查看Evernote原文. #@author: gr #@date: 2014-08-11 #@email: forgerui@gmail.com vector的相关问题.<stl学习> ...
- ###STL学习--迭代器
点击查看Evernote原文. #@author: gr #@date: 2014-08-23 #@email: forgerui@gmail.com STL中的迭代器. ###stl学习 |--迭代 ...
- ###STL学习--函数对象
点击查看Evernote原文. #@author: gr #@date: 2014-08-13 #@email: forgerui@gmail.com 在stl中,函数对象被大量地使用,用以提高代码的 ...
随机推荐
- AFNetwork2.0在报错1016,3840的解决方法及一些感悟
最近在学习AFNetwork,非常好的网络框架,能节省很多时间.不过请求网络数据时报错1016,3840. 这两个错误网上解决方法很多,http://blog.csdn.net/huifeidexin ...
- 【代码笔记】iOS-清除图片缓存UIActionSheet
一,效果图. 二,代码. RootViewController.m //点击任何处出现sheet -(void)touchesBegan:(NSSet *)touches withEvent:(UIE ...
- 【Andorid】短视频拍摄SDK——Vitamio Recorder 2.0 发布(支持ffmpeg命令行)
简介 VCamera SDK Android 版(短视频拍摄SDK)是炫一下(北京)科技有限公司推出的软件开发工具包,为Android开发者提供简单.快捷的接口,帮助开发者实现Android平台上的短 ...
- flashdevelop生成swc库
flashdevelop没有直接支持生成swc的工程,但flashdevelop生成swc也比较方便,不用任何插件. swc库是由 flexsdk的compc.exe生成的,其实我们通过这个命令行也可 ...
- 结对编程-地铁续(有种上个学期OO的既视感)
我们组比较特殊..三人结对 github:https://github.com/qingchanghan/WPFUI_Metro po一张照片: 石浩然,韩青长.陈彦吉 (台式机真的很高端,分屏贼帅) ...
- 5个示例带你学习AngularJS
直到现在,你或许已经听说过AngularJS了,一个改变你对web应用思考方式,由谷歌开发的令人兴奋的开源框架.关于它的文章已经写得非常之多,但我发现还是要写些给那些更喜欢快速且实际例子的开发者.当今 ...
- Redis简介
Redis是一个偏重于in-memory的key-value数据库,这样讲有点儿不准确,但是很容易将Redis简单分类.更准确的讲Redis是一个数据结构的存储服务.它的value不仅仅只有strin ...
- Oracle shutdown immediate遭遇ORA-24324 ORA-24323 ORA-01089
一数据库服务器执行shutdown immediate时,遇到了下面ORA错误,如下所示: $ sqlplus / as sysdba SQL*Plus: Release 10.2.0.4.0 - ...
- SQL Server 2012中Task是如何调度的?
SQL Server 2012中Task是如何调度的?[原文来自:How It Works: SQL Server 2012 Database Engine Task Scheduling] ...
- Oracle Latch的学习【原创】
Latch详解 - MaxChou 本文以学习为目的,大部分内容来自网络转载. 什么是Latch 串行化 数据库系统本身是一个多用户并发处理系统,在同一个时间点上,可能会有多个用户同时操作数据库.多个 ...