vector >bk;
vector MM;
MM.push_back(1);
MM.push_back(22);
MM.push_back(3);
MM.push_back(6);
bk.push_back(MM);
(1) vector
(2)vector
(3)vector
(4)vector
(5)int b[7]={1,2,3,4,5,9,8};vector
在STL中Vector这一容器,无论是在封装程度还是内存管理等方面都优于传统C++中的数组。本文主要是关于使用Vector初始化、遍历方面的内容。其他二维的思想也是类似的。
这里简单叙述一下C++ 构建二维动态数组
int **p;
p = new int*[10]; //注意,int*[10]表示一个有10个元素的指针数组
for (int i = 0; i < 10; ++i)
{
p[i] = new int[5];
}
定义一个二维整形数组并初始化:
vector > array(m); //这个m一定不能少//vector array[m];
//初始化一个m*n的二维数组
for(int i=0;i
例子
int main()
{
int i = 0, j = 0;
vector< vector > maze(8, vector (12, 0));
int A[8][12] = {{ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 },
{ 1, 0, 0, 1, 1, 0, 1, 0, 0, 0, 0, 1 },
{ 1, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 1 },
{ 1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1 },
{ 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 0, 1 },
{ 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1 },
{ 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1 },
{ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 }
};
int m, n;
for(m = 0; m < maze.size(); m++)
{
for(n = 0; n < maze[m].size(); n++)
{
maze[m][n] = A[m][n];
cout << maze[m][n] << " ";
}
cout << "\n";
}
}