C++_二维数组的动态申请内存3种方法

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;
优劣:行列都可以是变量,也很好写,但是用起来和二维数组不太一样,可能会有点麻烦 。

猜你喜欢

转载自blog.csdn.net/shyjhyp11/article/details/113524920