一、静态声明N*M的数组
int n = 5;
int m = 5;
int a[n][m];//内存连续
二、动态声明N*M的数组
与静态不同,动态申明的数组程序不会自己释放内存,必须手动释放,且内存未必连续(任意的p[k]都是一个int* 类型,即一个地址,所以只能p[i][j]或者 * (* (p+i) + j)来访问数组的元素,而不能a[i * n + j]使用。)
1.1、动态申明一个n*m的数组
int n = 5;
int m = 5;
int **P = new int*[n];
for(int i=0; i<n; i++){
p[i] = new int[m];
}
1.2、对数组赋值
for(int i=0; i<n; i++){
for(int j=0; j<m; j++){
p[i][j] = i+j;
}
}
1.33、释放内存
for (int i=0; i<n; i++){
delete [] p[i];
p[i] = NULL;
}
delete [] p;
p = NULL;
return 0;
三、利用vector来声明一个N×M数组
方法1
int n = 6;
int m = 6;
vector<vector<int>> a(n);//创建一个有row行的二维数组arr
for (int i = 0; i < n; i++)
a[i].resize(m);//设置每一行的元素个数,即列数
方法2
vector<vector<int> > a(n,vector<int>(m));
无需手动释放内存