C++中可以通过容器来建数组,二维数组
#include "stdafx.h"
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<int> col;
vector<vector<int>>array;
for (int i = 0; i<3; i++)
{
col.push_back(i);
col.push_back(i);
array.push_back(col);
col.erase(col.begin(), col.end());
//col.clear();
}
array.resize(2); //array.resize(m) 二维数组默认m行
array[1].resize(4); //array[1].resize(n)二维数组第2行默认n个元素
/*
int m=3;
int n=4;
array.resize(m);
for(int i = 0 ;i < m; i++)
arrar[i].resize(n);
*/
/*for (int i = 0; i < 3; i++) {
for (int j = 0; j < 2; j++) {
cout << array[i][j] << endl;
}
}//下标方式寻址 */
vector<vector<int>>::iterator IE;
vector<int>::iterator it;
for (IE = array.begin(); IE<array.end(); IE++)
{
for (it = (*IE).begin(); it<(*IE).end(); it++)
{
cout << *it << " ";
}
cout << endl;
}//迭代器寻址
return 0;
}
值得注意的是,在容器中,定义的大小对[]有效,而对push_back()
没有限制
vector<int> a(3);
cout << a.size() << endl;
//vector<vector<int>> matrix(M, vector<int>(N))
//a[3] = 1; error,越界
a.push_back(1);//push_back()则不用考虑vector的大小,直接在vector最后面添加元素
a.push_back(2);
a.push_back(3);
a.push_back(4);
cout << a.size() << endl;
vector<int>::iterator p;
p = a.begin();
printf("%p\n", p);
printf("%p\n", &a[0]);
printf("%p\n", &a.front());//a.front()为第一个元素的引用