C++ STL中的verctor就像是C语言中的数组,但是vector又具有数组没有的一些高级功能。可以说,vector就是数组的升级版。
1、头文件
#include <vector>
2、初始化
初始化格式为 vector<T> v;
其中,T为容器中所存放的数据类型,v是容器的名字。
//不初始化,仅声明
vector<int> v1;
vector<father> v2;
vector<string> v3;
vector<vector<int> >; //注意空格。这里相当于二维数组int a[n][n];
//既声明,也初始化
//1.利用列表初始化,注意使用的是花括号
vector<int> v5 = { 1,2,3,4,5 };
vector<string> v6 = { "hi","my","name","is","lee" };
//2.利用构造函数重载初始化
vector<int> v7(5, -1); //初始化为-1,-1,-1,-1,-1。第一个参数是数目,第二个参数是要初始化的值
vector<string> v8(3, "hi"); //容器中前3个数据初始化为hi
vector<int> v9(10); //默认初始化为0
vector<int> v10(4); //默认初始化为空字符串
如果如果vector的元素类型是int,默认初始化为0
如果vector元素类型为string,则默认初始化为空字符串
3、添加元素
利用push_back进行尾插法,即将元素插入容器尾
for(int a = 0;a < 10; a++)
{
v.push_back(a);
}
4、遍历容器中元素
注意:只能对已存在的元素进行赋值或者修改操作,若要加入新元素,一定要使用push_back进行尾插。push_back的作用有两个:告诉编译器为新元素开辟空间、将新元素存入新空间里。
vector<int> v;
cout << v[0] << endl;
以上代码是错误的,但是编译器不会报错,就像数组越界一样,v仅仅被声明,但是没有被初始化,v[0]没有开辟空间,故错误。
tip:每一个容器都有自己的迭代器,迭代器用来遍历容器中的数组
利用vector<int>::iterator 可以拿到vector<int>这种容器的迭代器类型
v.begin()指向容器中第一个元素位置
v.end()指向容器中最后一个元素的下一个位置
1.while循环遍历容器中元素
vector<int>::iterator pBegin = v.begin();
vector<int>::iterator pEnd = v.end();
while (pBegin != pEnd)
{
cout << *pBegin << endl;
pBegin++;
}
2.for循环遍历容器中元素
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it << endl;
}
3.使用STL提供标准遍历算法
需要添加头文件
#include <algorithm>
for_each()函数的三个参数作用 (起始参数,结束参数,函数)
for_each函数将从起始参数开始,到结束参数结束,将每一个参数传入函数执行
void print(int a)
{
cout << a << endl;
}
int main()
{
for_each(v.begin(), v.end(), print);
return 0;
}