若有定义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 ] 并不会出现越界访问