容器:vector
算法:for_each
迭代器:vector< int >::iterator
1. vector存放内置数据类型
#include<iostream>
#include<vector>
#include<algorithm>//标准算法头文件
using namespace std;
void myPrint(int val){
cout<<val<<endl;
}
void test1(){
//创建vector容器对象,并且通过模板参数指定容器中存放的数据的类型,可理解为数组
vector<int> v;
//向容器中存放数据
v.push_back(10);//尾插法
v.push_back(20);
v.push_back(30);
v.push_back(40);
//每一个容器都有自己的迭代器,迭代器是用来遍历容器中的元素
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;
}
//第三种遍历方式
for_each(v.begin(),v.end(),myPrint);//使用此函数需要包含算法头文件:algorithm
}
int main(){
test1();
system("pause");
return 0;
}
2. 存放自定义数据类型
#include<iostream>
#include<vector>
using namespace std;
//vector容器中存放自定义数据类型
class Person{
public:
string name;
int age;
public:
Person(string m,int a){name=m;age=a;}
};
void test1(){
vector<Person> v;
Person p1("aaa",12);
Person p2("bbb",13);
Person p3("ccc",14);
//向容器中添加数据
v.push_back(p1);
v.push_back(p2);
v.push_back(p3);
//遍历容器中的数据
for(vector<Person>::iterator it=v.begin();it!=v.end();it++){
cout<<"name:"<<(*it).name<<" age:"<<(*it).age<<endl;
}
}
void test2(){
vector<Person*> v;
Person p1("aaa",12);
Person p2("bbb",13);
Person p3("ccc",14);
//向容器中添加数据
v.push_back(&p1);
v.push_back(&p2);
v.push_back(&p3);
//遍历容器中的数据
for(vector<Person*>::iterator it=v.begin();it!=v.end();it++){
cout<<"name:"<<(*it)->name<<" age:"<<(*it)->age<<endl;
}
}
int main(){
test1();
test2();
system("pause");
return 0;
}
3. vector容器嵌套容器
#include<iostream>
#include<vector>
using namespace std;
//容器嵌套容器
void test1(){
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++){
for(vector<int>::iterator vit=(*it).begin();vit!=(*it).end();vit++){
cout<<*vit<<" ";
}
cout<<endl;
}
}
int main(){
test1();
system("pause");
return 0;
}
参考视频:https://www.bilibili.com/video/BV1et411b73Z?p=186