1.两层指针
先申请一个指针数组,再为数组中每个指针申请内存
//申请:
int **Matrix = new int*[ROW];
for (int i = 0; i < ROW; i++)
Matrix[i] = new int[COL];
//释放:
for (int i = 0; i < ROW; i++)
delete[] p[i];//先释放指针数组中的一级指针
delete[] p;//在释放二级指针
优劣:行和列都可以是变量,但是写起来麻烦。
2.给行指针申请内存
int (*a)[10]表示一个行指针,这个行指针指向10个int的一个数组。
(注:int *a[10]就是定义10个元素的指针数组)
int(*Matrix)[COL] = new int[ROW][COL];//为行指针申请row的内存
//也可以写作int(*A2)[COL] = (int(*)[COL])new int[ROW*COL];
delete[]Matrix;
优劣:好写好删除,但是列要是个常数 。
3.定义一级指针,直接申请一片内存
int *Matrix = new int[ROW*COL];
for (int i = 0; i < ROW*COL; i++)
cin >> Matrix[i];
for (int i = 0; i < ROW; i++)
{
for (int j = 0; j < COL; j++)
cout << Matrix[ROW*i + j] << " ";
cout << "\n";
}
delete Matrix;
优劣:行列都可以是变量,也很好写,但是用起来和二维数组不太一样,可能会有点麻烦 。