容器算法迭代器初识
1.1、vector存放内置数据类型
容器:vector
算法:for_each
迭代器:vector<int>::iterator
#include <iostream> #include <vector> #include <algorithm> //标准算法的头文件 using namespace std; void myPrint(int val) { cout << val << endl; } //vector存放内置数据类型 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; //} //第三种遍历方式 利用STL中提供的遍历算法 for_each (v.begin(), v.end(), myPrint); } int main() { test1(); system("pause"); return 0; }
10 | 20 | 30 | 40 |
1.2、vector存放自定义的数据类型
#include <iostream> #include <vector> #include <string> using namespace std; //vector容器中存放自定义的数据类型 class Person { public: Person(string name, int age) { this->m_Name = name; this->m_Age = age; } string m_Name; int m_Age; }; void test1() { vector<Person> v; Person P1("Tom", 10); Person P2("Jerry", 11); Person P3("John", 12); Person P4("Jack", 13); Person P5("King", 14); //向容器中添加数据 v.push_back(P1); v.push_back(P2); v.push_back(P3); v.push_back(P4); v.push_back(P5); //遍历容器中的数据 for (vector<Person>::iterator it = v.begin(); it != v.end(); it++) { //cout << "姓名:" << (*it).m_Name << " 年龄:" << (*it).m_Age << endl; cout << "姓名:" << it->m_Name << " 年龄:" << it->m_Age << endl; } } //存放自定义的数据类型 指针 void test2() { vector<Person*> v; Person P1("Tom", 10); Person P2("Jerry", 11); Person P3("John", 12); Person P4("Jack", 13); Person P5("King", 14); //向容器中添加数据 v.push_back(&P1); v.push_back(&P2); v.push_back(&P3); v.push_back(&P4); v.push_back(&P5); //遍历容器 for (vector<Person*>::iterator it = v.begin(); it != v.end(); it++) { cout << "姓名:: " << (*it)->m_Name << " 年龄::" << (*it)->m_Age << endl; } } int main() { test1(); test2(); system("pause"); return 0; }
1.3、vector容器嵌套容器
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++) { //(*it)——容器vector<int> for (vector<int>::iterator vit = (*it).begin(); vit != (*it).end(); vit++) { cout << *vit << " "; } cout << endl; } } int main() { test1(); system("pause"); return 0; }