顺序容器的种类有:vector,list、deque
顺序容器适配器:
stack //先进后出 栈
queue //先进先出 队列
priority_queue //也优先管理级的优先队列
1.头文件
#include#include #include
//每一种头文件对应一种顺序容器#include //队列 优先队列的头文件#include //栈的头文件
2.定义
vector v; listl; deque dq; //容器类型 <容器保存的数据类型> 容器名称; 容器保存的数据类型>
3.初始化 (以vector类型为例)
vectorv1; //创建一个空的容器 vector v2(n,i); //创建一个vector容器 其中包括n个值为i的元素 vector v3(v2); //创建一个v3 是v2的副本 vector v4(n); //创建一个有初始化的元素的n个副本 vector v5(v2.begin(),v2.end()-1); //创建v5 值为索引的中间值
注意:在初始化时,不同类型的容器之间 不能进行值的初始化
注意容器的定义时 有一种特殊情况 看下面的代码“
vector< vector >v3; //ok vector>v4; //ok vector >v5; //error
我们在写的时候 建议使用第一种写法 养成一个好的习惯
其实这第三种定义之所以不行 是因为它俩个>符号写在了一起 就会合成一个>>符号
4.迭代器的运算
所有迭代器都支持的运算
*iter //返回迭代器所指向的元素的引用 iter->name //获取迭代器指向元素中的name 容器中保持的是结构体 相等于(*iter).name. iter++(--) //iter 加减 ++(--)iter //和上面一样 只存在先加减和先运算的不同 iter1==(!=)iter2 //判断俩个迭代器所指 的元素是同一个
以下表图为string vector deque 类型迭代器支持的额外运算
注意:list容器只提供 上面所有迭代器都提供的运算 不能使用加减法与大小比较 (加减不同于自增自减)