牛客网 int a[3][4]

时间:2022-09-09 09:48:14

题目:  

int a[3][4],下面哪个不能表示 a[1][1]? 

A   *(&a[0][0]+5) 

B   *(*(a+1)+1) 

C   *(&a[1]+1) 

D   *(a[1]+1)

答案是C

困惑于B和C选项,编程实现一下。

#include <iostream>
using namespace std;
int main()
{
	int a[3][4];
	int k = 0;
	for(int i=0; i<3 ;i++)
	{
		for(int j=0; j<4; j++)
		{
			a[i][j] = ++k;
		}
	}  // 16 进制
	cout << a << endl;   // FA94
	cout << a+1 << endl;  //FAA4
	cout << *(a+1) << endl;  //FAA4
	cout << *(a+1)+1 << endl;  //FAA8
	cout << *(*(a+1)+1) << endl;  //6
	cout << endl;
	cout << a[1] << endl;  //FAA4
	cout << &a[1] << endl;  //FAA4
	cout << &a[1]+1 << endl;  //FAB4
	cout << *(&a[1]+1) << endl;  //FAB4
	cout << *(&a[1]+1)+1 << endl;  //FAB8
	cout << *(&a[1][0]+1) << endl;  //6
	return 0;
}

后面的注释是结果。

非常通俗的理解:

1. 基于a, a[]这种的加减运算,地址都是以“行”进行的。(这里体现为地址增加16位,因为数组是四列的)

   & 取址符号不影响运算的方式。

2. 在a, a[], &a, &a[], 情况下进行一次*操作,依旧是地址,但是加减运算切换为“列"模式。(这里体现为地址增加4位,因为是Int 类型)

   在上面的情况下,再次取*操作,此时就是地址中存储的数值了。


看到这个题目主要是两次取*操作有点懵,还有就是对a[1]取&操作的不理解。

二位数组在内存中是连续存储的,没有行和列的概念,这样理解好记一些吧。