指针对二维数组的访问

先来看一个代码:

#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 中指定位置的值。具体分解如下:

  1. *(*(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-1j-1:因为用户输入的索引是从 1 开始的,而数组索引是从 0 开始的,所以需要减去 1。
%d:分别表示 i-1、j-1 和对应的数组值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值