先来看一个代码:
#include <stdio.h>
int main()
{
int x[2][4];
int i,j,(*p)[4];
for (i=0;i<2;i++)
scanf("%d%d%d%d",&x[i][0],&x[i][1],&x[i][2],&x[i][3]);
p = x;
printf("input i and j:");
scanf("%d%d",&i,&j);
printf("x[%d][%d]=%d",i-1,j-1,*(*(p+i-1)+j-1));
return 0;
}
第十三行代码多少有点难看懂,这里作详解如下:
printf("x[%d][%d]=%d",i-1,j-1,*(*(p+i-1)+j-1));
这行代码的作用是输出二维数组 x 中指定位置的值。具体分解如下:
*(*(p + i - 1) + j - 1):
这是核心部分,用于计算二维数组中 (i-1, j-1) 位置的值。
p + i - 1
:p 是指向二维数组第一行的指针,因此 p + i - 1
表示指向第 i-1 行的指针(注意这里是从 0 开始计数)。
*(p + i - 1)
:获取第 i-1 行的地址。
*(p + i - 1) + j - 1
:在第 i-1 行的基础上,偏移到第 j-1 列的位置。
*(*(p + i - 1) + j - 1)
:解引用得到该位置的具体值。
2. printf("x[%d][%d]=%d", i-1, j-1, ...)
:
这是格式化输出语句,将结果打印到屏幕上。
i-1
和 j-1
:因为用户输入的索引是从 1 开始的,而数组索引是从 0 开始的,所以需要减去 1。
%d:分别表示 i-1、j-1 和对应的数组值。