【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷15及答案解析.doc

上传人:lawfemale396 文档编号:1332057 上传时间:2019-10-17 格式:DOC 页数:10 大小:60.50KB
下载 相关 举报
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷15及答案解析.doc_第1页
第1页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷15及答案解析.doc_第2页
第2页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷15及答案解析.doc_第3页
第3页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷15及答案解析.doc_第4页
第4页 / 共10页
【计算机类职业资格】国家二级C语言机试(函数和数组)模拟试卷15及答案解析.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

1、国家二级 C语言机试(函数和数组)模拟试卷 15及答案解析(总分:58.00,做题时间:90 分钟)一、选择题(总题数:29,分数:58.00)1.有下列程序: #includestdioh *fun 函数的功能是将 a所指数组元素从大到小排序* void fun(int*a,int n) main() int t,i,j; int c10=1,2,3,4,5,6,7,8,9,0),i; for(i=0;in-1j+) fun(c+4,6); for(j=i+1 jnj+) for(i=0;i10;i+)printf(“d,“,ci); if(aiaj)t=ai;ai=aj;aj=t;prin

2、tf(“n“); 程序的运行结果是(分数:2.00)A.1,2,3,4,9,8,7,6,5,0,B.0,9,8,7,6,5,1,2,3,4,C.0,9,8,7,6,5,4,3,2,1,D.1,2,3,4,5,6,7,8,9,0,2.有以下程序 #include main() int c6=10,20,30,40,50,60,*p,*s; p=c: s=&c5; printf(“dn“,s-p); 程序运行后的输出结果是(分数:2.00)A.50B.6C.5D.603.以下叙述中正确的是(分数:2.00)A.一条语句只能定义一个数组B.数组说明符的一对方括号中只能使用整型常量,而不能使用表达式C

3、.每个数组包含一组具有同一类型的变量,这些变量在内存中占有连续的存储单元D.在引用数组元素时,下标表达式可以使用浮点数4.以下叙述中正确的是(分数:2.00)A.语句 int a=0;是不合法的,遗漏了数组的大小B.语句 char a2=“A“,“B“;是合法的,定义了一个包含两个字符的数组C.语句 int a8=0;是合法的D.语句 char a3;a=“AB“:是合法的,因为数组有三个字符空间的容量,可以保存两个字符5.如果定义 float a10,x;则以下叙述中正确的是(分数:2.00)A.表达式 a+1是非法的B.语句 a=&x:是非法的C.三个表达式 a1、*(a+1)、*&a1表

4、示的意思完全不同D.表达式*a1是非法的,应该写成*(a1)6.有以下程序 #include main() int a=10,20,30,40),*p=a,i; for(i=0;i2!116.以下数组定义中错误的是(分数:2.00)A.int x3=0;B.int x23=1,2,3,4,5,6;C.int x3=1,2,3,4,5,6;D.int x23=1,2,3,4,5,6;17.有以下程序 #include #define N 4 void fun(int aN,int b) int i; for(i=0;iA.一 12,一 3,0,0,B.一 3,一 1,1,3,C.0,1,2,3,

5、D.一 3,一 3,一 3,一 3,18.有以下程序 #include main()int b33=0,1,2,0,1,2,0,1,2,i,j,t=l; for(i=0;i2!1 解析:解析:本题考查数组的使用,C 语言中数组的下标从 0开始。本题中 a是一个二维数组,两个下标的范围分别是 01和 02。选项 A中第一个下标越界,超出了范围;选项 B中第一个和第二个下标都超出了范围;选项 C中第二个下标超出范围;选项 D中,12 的值为 0,!1 的值为 0,因此选项 D实际是访问 a00。16.以下数组定义中错误的是(分数:2.00)A.int x3=0;B.int x23=1,2,3,4,

6、5,6; C.int x3=1,2,3,4,5,6;D.int x23=1,2,3,4,5,6;解析:解析:二维数组的初始化有以下几种形式:分行进行初始化;不分行的初始化;部分数组元素初始化;省略第一维的定义,不省略第二维的定义。在选项 B中赋值号左边定义了一个 3行 2列的二维数组,而右边用 2行 3列的数字进行赋初值。所以出现了边界的越界溢出而出错。17.有以下程序 #include #define N 4 void fun(int aN,int b) int i; for(i=0;iA.一 12,一 3,0,0,B.一 3,一 1,1,3, C.0,1,2,3,D.一 3,一 3,一 3

7、,一 3,解析:解析:fun 函数的功能是求出二维数组 a中第 i行第 i个元素与第 N-1-i元素的差,赋给 bi。在主函数中,把实参二维数组 x和一维数组 y传递给形参 a和 b,最后输出一维数组 y中元素的值。18.有以下程序 #include main()int b33=0,1,2,0,1,2,0,1,2,i,j,t=l; for(i=0;i=ij+) t+-bibii/; printf(“dn“,t); 程序运行后的输出结果是(分数:2.00)A.3B.1C.9D.4 解析:解析:这道题主要考查的是二维数组的有关知识。在两层 for循环语句中,每次执行变量 t的累加时,二维数组元素

8、b的第二下标的值与第一下标相同的值,所以程序执行的过程为 t=1+b11+b22=1+1+2=4。19.以下定义数组的语句中错误的是(分数:2.00)A.int num3=1,2),3,4,5,6;B.int num=1,2,3,4,5,6;C.int num4=1,2,3,4,5,6;D.int num24=1,2,3,4,5,6; 解析:解析:在选项 D的数组定义中,赋值号左边定义了一个 2行 4列的二维数组,而在右边定义了一个3行 2列的二维数组。20.有下列程序: main() int x32=0),i; for(i=0;i,则输出结果为(分数:2.00)A.2 0 0B.2 4 0C

9、.2 0 4 D.2 4 6解析:解析:语句 x32=0表示将二维数组 x的所有元素赋初值 0,而循环语句 for(i=0;i3;i+)scanf(“d“,xi)表示对数组元素 x00、x10、x20赋值。所以当运行程序时,输入246CR时,数组元素 x00=2、x10=4、x20=6,因此,输出数组元素 x00=2、x01=0、x10=4 的值 204。21.有以下程序 #include int fun(int(*s)4,int n,int k) int m,i; m=s0k; for(i=1;im)m=sik; return m;) main() int a44=1,2,3,4),11,1

10、2,13,14,21,22,23,24,31,32,33,34; printf(“dn“,fun(a,4,0); 程序的运行结果是(分数:2.00)A.31 B.34C.4D.32解析:解析:函数 funl(int(*s)4,int,int k)的功能是返回二维数组第 k列的最大元素。在主函数中由于二维数组 a44已经初始化,所以 fun(a,4,0)的值是二维数组 a第 1列中的最大元素 31。22.有下列程序: main() int a44=1,4,3,2,8,6,5,7,3,7,2,5,4,8,6,1),i,j,k,t; for(i=0;i4;i+) forfj=0;j3;j+) for

11、(k=j+1;k4;k+) iffajiaki)t=aji;aji=aki;aki=t; *按列排序* for(i=0;i4;i+)printf(“d,“,aii); 程序运行后的输出结果是(分数:2.00)A.8,7,3,1,B.1,6,5,7, C.4,7,5,2,D.1,6,2,1,解析:解析:最外层的 for语句的自变量 i是列下标,而内部的两个 for语句的自变量 i和 k是行下标。所以由程序段可知,这是利用三重循环对二维数组 a44的元素按列从小到大进行排序,所以最后排完序的结果为 a44=1,4,2,1),3,6,3,2,4,7,5,5,8,8,6,7,最后一个 for语句的功能

12、是输出数组 a44主对角线上的元素,因而输出为 1,6,5,7。23.有下列程序: main() int i,t3=9,8,7,6,5,4,3,2,1; for(i=0;iA.7 5 3B.3 6 9C.7 5 1D.3 5 7 解析:解析:由于在程序中定义了二维数组 t3=9,8,7,6,5,4,3,2,1:由二维数组的存储方式按行存储,即初始化完第一行的所有列再初始化下一行的元素。可知这是一个 3行 3列的二维数组,第一行的元素为9,8,7),第二行的元素为6,5,4),第三行的元素为3,2,1。然后用 for循环输出 t20、t11、t02,它们的值分别为 3、5、7。24.有下列程序:

13、 main() int a44=1,4,3,2,8,6,5,7,3,7,2,5,4,8,6,1),i,k,t; for(i=0;i4;k+)if(aiiA.6,2,1,1B.11,2,6,C.2,3,4,6,D.6,4,3,2, 解析:解析:利用二重 for循环对二维数组 a44的主对角线上的元素1,6,2,1实现按列从大到小排序,所以数组 a44的值变为6,4,3,2,8,2,5,7,3,7,1,5,4,8,6,1,最后输出数组 a44第一行上的元素,所以输出结果为 6,4,3,2。25.若有定义: int w35;则以下不能正确表示该数组元素的表达式是(分数:2.00)A.*(*w+3)B

14、.*(*(w+1)C.*(w+1)4 D.*(&w00+1)解析:解析:在 C语言中,二维数组的名字表示的是二维数组的地址,对于二维数组 im w35,可以认为 w为一个一维数组,含有 3个元素,而每个元素为一个含有 5个元素的一维数组。而(w+1)为一个含有两个元素的一维数组,首先和(w+1)4结合非法,4 超出了二维数组的边界,取值也就是非法的了。26.以下错误的定义语句是(分数:2.00)A.int x43=1,2,3,1,2,3,1,2,3,1,2,3);B.int x3=0,1,1,2,3;C.int xn3=1,2,3,4;D.int x4=1,2,3,1,2,3,1,2,3,1,

15、2,3); 解析:解析:一维数组定义和初始化是允许省略行下标,不允许省略列下标。27.以下叙述中正确的是(分数:2.00)A.语句 int a43=1,2,4,5;是错误的初始化形式B.语句 int a3=1,2,4,5);是错误的初始化形式C.在逻辑上,可以把二维数组看成是一个具有行和列的表格或矩阵 D.语句 int a43=1,2),4,5);是错误的初始化形式解析:解析:在理解二维数组的时候,可以把一个二维数组看成是一个一维数组,每个数组元素又是包含有若干个元素的一维数组,也就是具有行列的结构,二维数组初始化也是在类型说明时给各下标变量赋以初值。二维数组可按行分段赋值,也可按行连续赋值。

16、28.设有定义: int x23;则以下关于二维数组 x的叙述错误的是(分数:2.00)A.数组 x可以看作是由 x0和 x1两个元素组成的一维数组B.可以用 x0=0;的形式为数组所有元素赋初值 0 C.元素 x0可看作是由 3个整型元素组成的一维数组D.x0和 x1是数组名,分别代表一个地址常量解析:解析:二维数组的元素在内存中占一系列连续的存储单元。数组元素在内存中的排列顺序是先存放第 0行的元素,再存放第 1行的元素称这种存放顺序为按行存放。可以把一个二维数组看成是一个一维数组,每个数组元素又是包含有若干个元素的一维数一组。另外在给二维数组赋初值时可以不用含花括号对。例如,inta43

17、=1,2,4,5;在编译时,系统将按 a数组元素在内存中排列的顺序,将花括号内的数据一一对应地赋给各个元素,若数据不足,系统将给后面的元素自动补初值 0。以上将给 a数组第一行的元素和第二行的第一个元素依次赋予 1、2、4、5,其他元素的初值都为 0。29.有以下程序 #include #define N 3 void fun(int aN,int b) main() int ij; int xNN=1,2,3,4,5,6,7,8,9,yN,i; for(i=0;iA.1,3,5,B.2,4,8,C.3,5,7D.3,6,9, 解析:解析:函数 fun()的作用是求出二维数组 aN中每一行中的最大元素,所以在 main()函数中执行完 fun(x,y)后,数组 y中的元素为二维数组 xNN每一行的最大元素。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1