二维数组的指针表示法
1.二维数组地址
设有 int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}};
对于行元素 a[0],a[1],a[2];数组a是他们的首地址,因此a+1代表a[1]地址
对于第0行元素,可以看成a[0]四个元素。把a[0]看成一个数组名,这样a[0]代表第0行的首地址,也是第0行0列元素的地址&a[0][0],该行的其它元素地址可以可用数组名加序号来表示:a[0]+1
2,二维数组的指针
a[i][j]=*(a[i]+j)= *( *(a+i)+j)
3,二维数组元素的引用方式
用不同的方法输出二维数组元素
#include<iostream>
using namespace std;
void main()
{
static int a[2][3] = { 1,2,3,4,5,6 };
int i, j, * p = NULL;
for (i = 0; i < 2; i++)
{
for (j = 0; j < 3; j++)
cout << a[i][j] << " ";
cout << endl;
}
cout << endl;
for (i = 0; i < 2; i++)
{
for (j = 0; j < 3; j++)
cout <<*(a[i]+j) << " ";
cout << endl;
}
cout << endl;
for (i = 0; i < 2; i++)
{
for (j = 0; j < 3; j++)
cout << *(*(a+i)+j)<< " ";
cout << endl;
}
cout << endl;
p = a[0];
for (i = 0; i < 2; i++)
{
for (j = 0; j < 3; j++)
cout <<*(p++) << " ";
cout << endl;
}
}
结果
4,指向二维数组的指针变量
指向二维数组的指针变量有两种情况:一是直接指向数组元素的指针变量;二是指向一个含有M个元素的一维数组的指针变量。这两种不同形式的指针变量,其定义与使用方法是不一样的
(1)直接指向数组元素的指针变量
如
p = a[0];
for (i = 0; i < 2; i++)
{
for (j = 0; j < 3; j++)
cout <<*(p++) << " ";
cout << endl;
}
(2)指向一个含有M个元素的一维数组的指针变量,也称为行指针
定义形式:
int (*p)[5];
int a[3][4]={1,2,3,4,5,6,7,8,9,10,11,12} ;
表示形式 | 含义 |
---|---|
a | 首地址,0行首地址 ——行指针 |
a[0],*(a+0),*a | 第0行第0列元素地址——列指针 |
a+1,&a[1] | 第一行首地址 ——行指针 |
a[1],*(a+1) | 第一行第0列地址——列指针 |
a[1]+2,*(a+1)+2,&a[1][2] | 第一行第二列元素地址——列指针 |
*(a[1+2]), *( *(a+1)+2),a[1][2] | 第一行第二列元素 |
用指向一维数组的行指针输出二维数组,并将数组中最大元素及所在的行号输出
#include<iostream>
using namespace std;
void main()
{
int i, j, row, colum, max;
int a[3][4] = { 8,10,3,4,11,6,7,1,9,2,5,12 };
int(*p)[4]; //定义p为指向一个有4元素的一维数组指针变量
p = a;
max = **p; //**p相当于*(*(p+0)+0)
row = 0;
colum = 0;
for (i = 0; i < 3; i++)
{
cout << endl;
for (j = 0; j < 4; j++)
{
cout << *(*p + j)<<" ";
if (max < *(*p + j))
{
max = *(*p + j);
row = i;
colum = j;
}
}
p++;
}
cout << "\nmax is:a[" << row << "][" << colum << "]=" << max << endl;
}
结果