vector 建立二维数组
作者:互联网
方法一:
#include <iostream> #include <vector> using namespace std; void test01() { //创建一个外层容器 vector<vector<int>>v; //创建一些内层容器,并赋值 vector<int>v1(10,1); vector<int>v2(10,2); vector<int>v3(10,3); //将内层小容器插入到大容器之中,类似于二维数组。 v.push_back(v1); v.push_back(v2); v.push_back(v3); }
遍历访问:
1.得到的行列大小,利用类似于数组访问
void reverse_with_index(vector<vector<int>> vec) { if (vec.empty()) { cout << "The vector is empty!" << endl; return; } int i,j; cout << "Use index : " << endl; for (i = 0; i < vec.size(); i++) { for(j = 0; j < vec[0].size(); j++) cout << vec[i][j] << " "; cout << endl; } } /*———————————————— 版权声明:本文为CSDN博主「雪伦_」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/a819825294/article/details/52088732 */
2.利用迭代器开始遍历
for (vector<vector<int>>::iterator it = v.begin(); it != v.end(); it++) { for (vector<int>::iterator it1 = (*it).begin(); it1 != (*it).end(); it1++) { cout << *it1 << " "; } cout << endl; }
方法二:一维扩充法
#include <iostream> #include <vector> //如果想用vector必须包含对应头文件 using namespace std; int main() { vector<vector<int> > vec(m); //这里m就是相当于二维数组的行数,必须写,不然报错 //这里创建一个m*n的二维vector for(int i = 0;i<m;i++) {//这里是给内层vector定义大小。默认是0,这里n是个数,不是值 vec[i].resize(n); //利用resize进行扩充 } //赋值,我尝试了一下vec.[i].push_back(10)来为其赋值,不过失败了,可能不可以这样做。 for (int i = 0; i < 3; i++) { for (int j = 0; j < 5; j++) { vec[i][j] = j + 100; } } system("pause"); return 0; }
————————————————
版权声明:本文为CSDN博主「why you learn hard?」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/hacker_zrq/article/details/112162049
标签:back,二维,vector,vec,数组,include,it1 来源: https://www.cnblogs.com/luyufan/p/15966000.html