牛客网 int a[3][4]

  • Post author:
  • Post category:其他


题目:

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]取&操作的不理解。

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



版权声明:本文为weixin_40103549原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。