vector容器,类似数组
容器在使用前需要包含头文件
容器:vector
算法:for_each
迭代器:vector<int>::itreator
push_back 往容器中插入数据
vector<int> v;
v.push_back(10);
v.push_back(20);
遍历容器数据的三个方法
vector<int>::iterator itbegin = v.begin();//起始迭代器 指向容器中第一个元素
vector<int>::iterator itend = v.end();//结束迭代器 指向容器中最后一个元素
while (itbegin != itend)
{
cout << *itbegin << endl;
itbegin++;
}
for (vector<int>::iterator it = v.begin(); it != v.end(); it++)
{
cout << *it << endl;
}
使用STL的算法for_each来实现遍历容器,首先需要包含#include<algorithm>
void MyPrint(int val)
{
cout << val << endl;
}
int main()
{
vector<int> v;
v.push_back(10);
v.push_back(20);
for_each(v.begin(), v.end(), MyPrint);
}
vector容器嵌套容器
vector<vector<int>> v;
//创建小容器
vector<int> v1;
vector<int> v2;
vector<int> v3;
vector<int> v4;
//向小容器中添加数据
for (int i = 0; i < 4; i++)
{
v1.push_back(i + 1);
v2.push_back(i + 2);
v3.push_back(i + 3);
v4.push_back(i + 4);
}
//将小容器插入到大容器中
v.push_back(v1);
v.push_back(v2);
v.push_back(v3);
v.push_back(v4);
//通过大容器把所有数据遍历一遍
for (vector<vector<int>>::iterator it = v.begin(); it != v.end(); it++)
{
//(*it)---容器vector<int>
for ( vector<int>::iterator vit = (*it).begin(); vit != (*it).end(); vit++)
{
cout << *vit << " ";
}
cout << endl;
}