C/C++每日一题

若有定义int a[ 10 ], b[3][3]; ,则以下对数组元素的赋值操作中,不会出现越界访问的是:

A a[-1]=0 B a[10] = 0 C b[3][0] = 0 D b[0][3] = 0

先自己思考一下~

首先我们可以排除A和C选项

A: 因为数组的下标不能为负数

B:int a[10]中只有十个元素(a[0]—a[9]),而a[10]的元素越界了

但是C选项和D选项,乍一看,不是都越界了吗?

b[ 3 ][ 3 ]为一个三行三列的数组,b[ 3 ][ 0 ]可看为第四行的第一个元素,但是b数组所创建的数组大小只有三行三列,所以C选项的b[ 3 ][ 0 ]为越界访问

可是D选项呢?

我们知道,二维数组的只是我们人臆想出来的,其实二维数组在计算机里储存的本质为一维数组(数组元素一直向后延申)

类似如图 :

故我们可以猜想:b[ 0 ][ 3 ]是否会占用b[ 1 ][ 0 ] 的位置,从而完成储存呢?

我们利用代码来看一下

int main(void) 
{

	int b[3][3] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

	for (int i = 0; i < 3; i++) {

		for (int j = 0; j < 3; j++) {
			printf("%d ", b[i][j]);
		}
		printf("\n");
	}
		printf("\n"); 
		b[0][3] = 0;

		for (int i = 0; i < 3; i++) {

			for (int j = 0; j < 3; j++) {
				printf("%d ", b[i][j]);
			}
			printf("\n");
		}
		printf("\n");

		return 0;
}

我们可以发现,如果真的要读取b[ 0 ][ 3 ]处的数据时会发现,他会利用b[ 1 ][ 0 ]的空间

故D选项b[ 0 ][ 3 ] 并不会出现越界访问

猜你喜欢

转载自blog.csdn.net/m0_66307842/article/details/123698922