首先说结论 :
int(*p)[2] = new int[3][2]{ {1,2},{3,4},{5,6} };
// 或者 int(*p)[2] = new int[3][2];
左边的意思是申明了一个数组指针,该指针指向一个数组,如int (*p)[2]的意思为申明一个指针p指向一个长度为2的数组,该数组的元素类型为int。int(*p)[2] = new int[3][2];这里p指针指向的长度为2的数组,如果你把p指针加1后输出p指针会发现其结果为地址,且输出的地址加了8个字节,也就是跳过了2个int类型的数据,其实此时是指针p由指向二维数组的[0][0]变为指向[1][0]再变为指向[2][0],所以我的理解是该指针就是指向二维数组每一行的指针,指针加1即指向了数组的下一行。要想求作为为[i][j]的值,有两种方法:1、先p+i让指针p指向第二维数组第i行,解引用*p(因为p指向的是数组,解引用不能直接输出数组,而会得到该行一维数组的首地址)得到该行一维数组的首地址,定义指针q(int *q)来接收*p,然后q+j使指针指向我们要定位的坐标,最后*q求得该坐标的值 2、直接cout<<p[i][j]<<endl; 推荐使用第二种方法 简单一些
注意:c++中此时二维数组每个元素地址是连续的
其它方法:
创建[m][n]二维数组
double *d[m]; for (int i=0; i<m; i++) { d[i] = new double[n];}
缺点:申请的空间不能连续且需要多个指针才能管理