C语言的数组问题,若有定义:int a[2][3];以下选项中对a数组元素正确引用的是 A.a[2][!1] B.a[2][3]

C.a[0][3] D.a[1>2][!1]

选D。

一个二维数组可以被认为是一个带有 x 行和 y 列的表格。下面是一个二维数组,包含 2 行和 3列:

因此,数组中的每个元素是使用形式为 a[ i , j ] 的元素名称来标识的,其中 a 是数组名称,i 和 j 是唯一标识 a 中每个元素的下标。i最大值为1,j最大值为2,超出此范围则表示错误。

扩展资料:

数组使用规则:

1.可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只给前面部分元素赋值。例如:static int a[10]={0,1,2,3,4};表示只给a[0]~a[4]5个元素赋值,而后5个元素自动赋0值。

2.只能给元素逐个赋值,不能给数组整体赋值。例如给十个元素全部赋1值,只能写为:static int a[10]={1,1,1,1,1,1,1,1,1,1};而不能写为:static int a[10]=1;(请注意:在C、C#语言中是这样,但并非在所有涉及数组的地方都这样,数据库是从1开始。)

3.如不给可初始化的数组赋初值,则全部元素均为0值。

4.如给全部元素赋值,则在数组说明中, 可以不给出数组元素的个数。例如:static int a[5]={1,2,3,4,5};可写为:static int a[]={1,2,3,4,5};动态赋值可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。

参考资料:

百度百科-数组

温馨提示:内容为网友见解,仅供参考
第1个回答  2020-05-21
D 因为1>2为假,所以表达式为0 ; 其次!1也就是非真,即为假,所以a[1>2][!1]等价于a[0][0]
第2个回答  推荐于2018-02-27
D,
数组的有效范围是a[0][0] - a[1][2]
A,B,C都超过范围了。本回答被网友采纳
第3个回答  2012-03-13
定义的数组引用时那个数下标减1
第4个回答  2019-04-12
D
其他的都越界
相似回答