ACM___________________________

______________白白の屋
posts - 182, comments - 102, trackbacks - 0, articles - 0

STL 学习笔记 ( 一. 概述 )

Posted on 2010-08-31 21:47 MiYu 阅读(1433) 评论(0)  编辑 收藏 引用 所属分类: ACM_资料

 MiYu原创, 转帖请注明 : 转载自 ______________白白の屋    

 

几种常用的容器: map, vector, list, queue,stack, string ( 这个字符串也算个容器 ) 

 

STL容器的共通操作

 

一. 初始化(initialization

 

 

1.产生一个空容器

 

list<int> l;  vector<int> vec;  map<int,int>.......

 

尖括号里面可以是系统类型, 也可以是自定义类型, 表示存放在容器中的类型.

 

2.以另一个容器元素为初值完成初始化

 

  list<int> lst;

 

 

vector<float> vec ( lst.begin(), lst.end() );  

 

  其他的容器都可以类似地 操作, 当然, 每一种容器都有好几个构造函数版本,

具体下面分类介绍.

 

以数组元素为初值完成初始化 

 

int array[]={2,4,6,1345};

 

 

set<int> st ( array, array + sizeof(array) / sizeof(array[0]) );

 

与大小相关的操作(size operator

 

size()-返回当前容器的元素数量

 

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

 

max_size()-返回容器能容纳的最大元素数量

 

比较(comparison

 

==,!=,<,<=,>,>=

 

比较操作两端的容器必须属于同一类型

 

如果两个容器内的所有元素按序相等,那么这两个容器相等

 

采用字典式顺序判断某个容器是否小于另一个容器

 

赋值(assignment)和交换(swap

 

swap用于提高赋值操作效率

 

容器的共通操作

 

与迭代器iterator相关的操作

 

begin()-返回一个迭代器,指向第一个元素

 

end()-返回一个迭代器,指向最后一个元素之后

 

rbegin()-返回一个逆向迭代器,指向逆向遍历的第一个元素

 

rend()-返回一个逆向迭代器,指向逆向遍历的最后一个元素之后

 

元素操作

 

insert(pos,e)-将元素e的拷贝安插于迭代器pos所指的位置

 

erase(beg,end)-移除[begend]区间内的所有元素

 

clear()-移除所有元素

 

迭代器(iterator)(示例:iterator

 

->可遍历STL容器内全部或部分元素的对象

 

->指出容器中的一个特定位置

 

->迭代器的基本操作

 

操作
效果
*
返回当前位置上的元素值。如果该元素有成员,可以通过迭代器以operator ->取用
++
将迭代器前进至下一元素
==!=
判断两个迭代器是否指向同一位置
=
为迭代器赋值(将所指元素的位置赋值过去)


迭代器(iterator

 

所有容器都提供获得迭代器的函数 

 

操作
效果
begin()
返回一个迭代器,指向第一个元素
end()
返回一个迭代器,指向最后一个元素之后

 

 

半开区间[beg, end)的好处:

 

1.为遍历元素时循环的结束时机提供了简单的判断依据(只要未到达end(),循环就可以继续

 

2.不必对空区间采取特殊处理(空区间的begin()就等于end()

 

 

所有容器都提供两种迭代器

 

container::iterator读/写模式遍历元素

 

container::const_iterator只读模式遍历元素

 

        迭代器示例:iterator

 

 

 

 

迭代器分类

 

双向迭代器

 

->可以双向行进,以递增运算前进或以递减运算后退。

 

->listsetmap提供双向迭代器

 

随机存取迭代器

 

->除了具备双向迭代器的所有属性,还具备随机访问能力。

 

->可以对迭代器增加或减少一个偏移量、处理迭代器之间的

 

  距离或者使用<>之类的关系运算符比较两个迭代器。

 

->vectordequestring提供随机存取迭代器

 

 

 

 


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理