版权声明:个人爱好,可随便转载 https://blog.csdn.net/qq_43528087/article/details/88927095
常规法:数组指针:
int a[2][3] = { 1, 2, 3, 4, 5, 6 };
for (int i = 0; i < 2; i++)
for (int j = 0; j < 3; j++)
cout <<*(a[i]+j)<< endl;//*(a[i]+j)等价于*(*(a+i)+j)
指针法:定义行指针:
类型标识符 (*指针变量名) [m]; //m是长度(列数)
代码如下:
int a[2][3] = { 1, 2, 3, 4, 5, 6 };
int (*p)[3] = a; //此时a等价于&a[0]
cout << p[0][0] << endl;
cout << p[0][1] << endl;
cout << p[0][2] << endl;
cout << p[1][0] << endl;
cout << p[1][1] << endl;
cout << p[1][2] << endl;
此时p不再是指向一个具体的数值,而是指向包含m个元素的一维数组