更新时间:2015-12-20 19:18:55浏览次数:1+次
首先,需要明确的是,在计算机的世界中,根本不存在二维数组,只是使用者的一个概念罢了。其实我们所谓的二维数组也必须是一段连续的内存。
很多情况下,我们可以把常规的二维数组用一个vector表示,只要索引对应即可。
那么,我若一意孤行呢,我就想vector里面放一个vector呢?
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector <vector<int>> array(3);
for (int i = 0; i <3; i++)
array[i].resize(3);
for (int i = 0; i <3; i++)
for (int j = 0; j <3; j++)
array[i][j] = (i*j);
for (int i = 0; i <3; i++)
{
for (int j = 0; j <3; j++)
cout <<array[i][j] << " ";
cout <<endl;
}
array.resize(5);
array[3].resize(3);
array[4].resize(3);
//现在是5X3的数组了
cout << endl << endl;
for (int i = 0; i <5; i++)
for (int j = 0; j <3; j++)
array[i][j] = (i*j);
for (int i = 0; i <5; i++)
{
for (int j = 0; j <3; j++)
cout <<array[i][j] << " ";
cout <<endl;
}
}
//输出:
0 0 0
0 1 2
0 2 4
0 0 0
0 1 2
0 2 4
0 3 6
0 4 8
就是再使用“列”的时候,需要使用vector的resize方法,否则不能使用[]进行访问的。
这里也不能用vector的reserve分配容量,原因上一篇博客已经分析过了。
其实我想说的就是,如果想要构建所谓的二维数组,最重要的就是要使用resize分配容量。
相关资讯