1、二级公共基础知识-56 及答案解析(总分:100.00,做题时间:90 分钟)一、单项选择题(总题数:40,分数:100.00)1.下列关于栈和队列的描述中,正确的是_。A栈是先进先出 B队列是先进后出C队列允许在队尾删除元素 D栈在栈顶删除元素(分数:2.50)A.B.C.D.2.已知二叉树后序遍历序列是 CDABE,中序遍历序列是 CADEB,它的前序遍历序列是_。AABCDE BECABD CEACDB DCDEAB(分数:2.50)A.B.C.D.3.在数据流图中,带有箭头的线段表示的是_。A控制流 B数据流 C模块调用 D事件驱动(分数:2.50)A.B.C.D.4.结构化程序设计的
2、 3 种结构是_。A顺序结构,分支结构,跳转结构 B顺序结构,选择结构,循环结构C分支结构,选择结构,循环结构 D分支结构,跳转结构,循环结构(分数:2.50)A.B.C.D.5.下列方法中,不属于软件调试方法的是_。A回溯法 B强行排错法 C集成测试法 D原因排除法(分数:2.50)A.B.C.D.6.下列选项中,不属于模块间耦合的是_。A内容耦合 B异构耦合 C控制耦合 D数据耦合(分数:2.50)A.B.C.D.7.下列特征中不是面向对象方法的主要特征的是_。A多态性 B标识唯一性 C封装性 D耦合性(分数:2.50)A.B.C.D.8.在数据库设计中,将 E-R 图转换成关系数据模型的
3、过程属于_。A需求分析阶段 B概念设计阶段 C逻辑设计阶段 D物理设计阶段(分数:2.50)A.B.C.D.9.在一棵二叉树上,第 5 层的结点数最多是_。A8 B9 C15 D16(分数:2.50)A.B.C.D.10.下列有关数据库的描述,正确的是_。A数据库设计是指设计数据库管理系统B数据库技术的根本目标是要解决数据共享的问题C数据库是一个独立的系统,不需要操作系统的支持D数据库系统中,数据的物理结构必须与逻辑结构一致(分数:2.50)A.B.C.D.11.以下叙述错误的是_。AC 语言区分大小写BC 程序中的一个变量,代表内存中一个相应的存储单元,变量的值可以根据需要随时修改C整数和实
4、数都能用 C 语言准确无误地表示出来D在 C 程序中,正整数可以用十进制、八进制和十六进制的形式来表示(分数:2.50)A.B.C.D.12.下列叙述中错误的是_。A用户所定义的标识符允许使用关键字B用户所定义的标识符应尽量做到“见名知意”C用户所定义的标识符必须以字母或下划线开头D用户定义的标识符中,大、小写字母代表不同标识(分数:2.50)A.B.C.D.13.下列选项中可作为 C 语言合法常量的是_。A-80 B-080 C-8e1.0 D-80.0e(分数:2.50)A.B.C.D.14.下列定义变量的语句中错误的是_。Aint_int; Bdoubleint_; Cchar For;
5、 Dfloat US$;(分数:2.50)A.B.C.D.15.下列关于函数的叙述中正确的是_。A每个函数都可以被其他函数调用(包括 main 函数)B每个函数都可以被单独编译C每个函数都可以单独运行D在一个函数内部可以定义另一个函数(分数:2.50)A.B.C.D.16.当 a=1、b=2、c=3、d=4 时,执行下面程序段后,x 的值是_。if(ab)if(cd)x=1;elseif(ac)if(bd)x=2;else x=3;else x=6;else x=7;A1 B6 C3 D2(分数:2.50)A.B.C.D.17.以下程序的输出结果是_。#includestdio.hmain()
6、int a=4,b=3,c=2,d=1;printf(“%d“,ab?a:dc?d:b);A1 B3 C2 D4(分数:2.50)A.B.C.D.18.若有语句“char*line5”,下列叙述中正确的是_。A定义 line 是一个数组,每个数组元素是一个基类型为 char 的指针变量B定义 line 是一个指针变量,该变量可以指向一个长度为 5 的字符型数组C定义 line 是一个指针数组,语句中的*号称为间址运算符D定义 line 是一个指向字符型函数的指针(分数:2.50)A.B.C.D.19.以下程序:#includestdio.hmain()char str10;scanf(“%S“
7、,printf(“%S/n“,str);运行上面的程序,输入字符串 how are you,则程序的执行结果是_。Ahow Bhow are you Ch Dhowareyou(分数:2.50)A.B.C.D.20.设 x 和 y 都是 int 类型,且 x=1,y=2,则 printf(“%d%d“x,y,(x,y)的输出结果是_。A12 B122 C1,2 D输出值不确定(分数:2.50)A.B.C.D.21.以下程序的输出结果是_。#includestdio.hmain()int a=8,b=6,m=1;switch(a%4)case 0:m+;break;case 1:m+;switc
8、h(b%3)default:m+;case 0:m+;break;printf(“%d/n“,m);A1 B2 C3 D4(分数:2.50)A.B.C.D.22.定义如下变量和数组:inti;int x33=1,2,3,4,5,6,7,8,9;则下面语句的输出结果是_。for(i=0;i3;i+)printf(“%d“,xi2-i);A159 B147 C357 D369(分数:2.50)A.B.C.D.23.有下列程序段:typedef struct NODEint num;struct NODE*next;OLD;下列叙述中正确的是_。A以上的说明形式非法 BNODE 是一个结构体类型CO
9、LD 是一个结构体类型 DOLD 是一个结构体变量(分数:2.50)A.B.C.D.24.下列数组定义中错误的是_。Aint x3=0; Bint x23=1,2,3,4,5,6;Cint x3=1,2,3,4,5,6; Dint x23=1,2,3,4,5,6:(分数:2.50)A.B.C.D.25.以下叙述错误的是_。A变量的作用域取决于变量定义语句的位置B全局变量可以在函数以外的任何部位进行定义C局部变量的作用域可用于其他函数的调用D一个变量说明为 static 存储类型是为了限制其他编译单元的引用(分数:2.50)A.B.C.D.26.若定义函数 int*func(),则函数 func
10、 的返回值为_。A一个实数 B一个指向整型变量的指针C一个指向整型函数的指针 D一个整型函数的入口地址(分数:2.50)A.B.C.D.27.若有以下定义,则正确引用数组元素的是_。int a5,*p=a;A*若以下选项中所用变量都已正确定义并赋值,错误的函数调用是_。Aif(fun(x,y) Bz=fun(fun(x,y),fun(x,y);Cz=fun(fun(x,y)x,y); Dfun(x,y);(分数:2.50)A.B.C.D.30.执行以下语句段后,xy 的值是_。int*pt,xy;xy=200;pt=xy=*pt+30;A200 B170 C260 D230(分数:2.50)A
11、.B.C.D.31.下述程序的输出结果是_。#includestdio.hvoid main()int a20,*p4;int i,k=0;for(i=0;i20;i+)ai=i;for(i=0;i4;i+)pi=for(i=0;i4;i+)k=k+*pi;printf(“%df“,k);A10 B18C6 D数组元素引用不合法,输出结果不定(分数:2.50)A.B.C.D.32.下面各语句行中,能正确进行赋值字符串操作的是_。Achar s5=a,b,c,d,e; Bchar*s;gets(s);Cchar*s;s=“ABCDEF“; Dchars5;scanf(“%s“,(分数:2.50)
12、A.B.C.D.33.下面程序的输出结果是_。#includestdio.hmain()char a=a,b,c,d,f,g,*p;p=a;printf(“%c/n“,*p+4);Aa Bb Ce Df(分数:2.50)A.B.C.D.34.下面函数的功能是_。sss(s,t)char*s,*t;while(*s);while(*t)*(s+)=*(t+);return s;A将字符串 s 复制到字符串 t 中 B比较两个字符串的大小C求字符串的长度 D将字符串 t 续接到字符串 s 中(分数:2.50)A.B.C.D.35.下列程序的运行结果是_。#includestdio.hvoid su
13、b(int*s,int*y)static int m=4;*y=sm;m-;void main()int a=1,2,3,4,5,k;int x;printf(“/n“);for(k=0;k=4;k+)sub(a,printf(“%d,“,x);A5,4,3,2,1, B1,2,3,4,5, C0,0,0,0,0, D4,4,4,4,4,(分数:2.50)A.B.C.D.36.设 q1 和 q2 是指向一个 int 型一维数组的指针变量,k 为 float 型变量,下列不能正确执行的语句是_。Ak=*q1*(*q2); Bq1=k;Cq1=q2; Dk=*q1+*q2;(分数:2.50)A.B
14、.C.D.37.下列程序的输出结果为_。main()union unchar*name;int age;int pay;s;s.name=“zhaoming“;s.age=32;s.pay=3000;printf(“%d/n“,s.age);A32 B3000 C0 D不确定(分数:2.50)A.B.C.D.38.以下有关宏替换的叙述不正确的是_。A使用宏定义可以嵌套 B宏定义语句不进行语法检查C双引号中出现的宏名不替换 D宏名必须用大写字母表示(分数:2.50)A.B.C.D.39.下列程序执行输出的结果是_。#includestdio.hf(int a)int b=0;static c=3
15、;a=c+;b+;return(a);main()int a=2,i,k;for(i=0;i2;i+)k=f(a+);printf(“%d/n“,k);A3 B4 C5 D6(分数:2.50)A.B.C.D.40.已知函数的调用形式为“fread(buffer,size,count,fp)”,其中 buffer 代表的是_。A一个整型变量,代表要读入的数据项总数B一个文件指针,指向要读的文件C一个指针,是指向的输入数据放在内存中的起始位置D一个存储区,存放要读的数据项(分数:2.50)A.B.C.D.二级公共基础知识-56 答案解析(总分:100.00,做题时间:90 分钟)一、单项选择题(总
16、题数:40,分数:100.00)1.下列关于栈和队列的描述中,正确的是_。A栈是先进先出 B队列是先进后出C队列允许在队尾删除元素 D栈在栈顶删除元素(分数:2.50)A.B.C.D. 解析:解析 栈实际也是线性表,只不过是一种特殊的线性表。栈是只能在表的一端进行插入和删除运算的线性表,通常称插入、删除的这一端为栈顶,另一端为栈底。队列是只允许在一端删除,在另一端插入的顺序表。允许删除的一端叫做队头,允许插入的一端叫做队尾。2.已知二叉树后序遍历序列是 CDABE,中序遍历序列是 CADEB,它的前序遍历序列是_。AABCDE BECABD CEACDB DCDEAB(分数:2.50)A.B.
17、C. D.解析:解析 由于后序遍历的最后一个元素为 E,所以 E 为根结点,所以它的前序遍历的首个元素为 E,故排除 A 和 D 选项。由于中序遍历中,元素 B 在元素根结点 E 的后面,所以 B 为二又树的右子树,并且该二又树右子树只有一个元素,所以前序遍历的最后一个元素应为 B,故选项 C 为正确选项,即该二叉树的前序遍历序列是 EACDB。3.在数据流图中,带有箭头的线段表示的是_。A控制流 B数据流 C模块调用 D事件驱动(分数:2.50)A.B. C.D.解析:解析 数据流图中带箭头的线段表示数据流,沿箭头方向传递数据的通道,一般在旁边标注数据流名。4.结构化程序设计的 3 种结构是
18、_。A顺序结构,分支结构,跳转结构 B顺序结构,选择结构,循环结构C分支结构,选择结构,循环结构 D分支结构,跳转结构,循环结构(分数:2.50)A.B. C.D.解析:解析 程序设计语言仅仅使用顺序、选择和重复(循环)3 种基本控制结构就足以表达出各种其他形式结构的程序设计方法。遵循程序结构化的设计原则,按结构化程序设计方法设计出的程序易于理解、使用和维护,可以提高编程工作的效率,降低软件的开发成本。5.下列方法中,不属于软件调试方法的是_。A回溯法 B强行排错法 C集成测试法 D原因排除法(分数:2.50)A.B.C. D.解析:解析 软件调试主要采用以下 3 种方法。强行排错法:作为传统
19、的调试方法,其过程可概括为设置断点、程序暂停、观察程序状态、继续运行程序。回溯法:该方法适合于小规模程序的排错,即一旦发现了错误,先分析错误征兆,确定最先发现“症状”的位置。原因排除法:通过演绎和归纳,以及二分法来实现。6.下列选项中,不属于模块间耦合的是_。A内容耦合 B异构耦合 C控制耦合 D数据耦合(分数:2.50)A.B. C.D.解析:解析 耦合可以分为下列几种,它们之间的耦合度由高到低排列。内容耦合:若一个模块直接访问另一模块的内容,则这两个模块称为内容耦合。公共耦合:若一组模块都访问同一全局数据结构,则称为公共耦合。外部耦合:若一组模块都访问同一全局数据项,则称为外部耦合。控制耦
20、合:若一模块明显地把开关量、名字等信息送入另一模块,控制另一模块的功能,则称为控制耦合。标记耦合:若两个以上的模块都需要其余某一数据结构的子结构时,不使用其余全局变量的方式而全使用记录传递的方式,这样的耦合称为标记耦合。数据耦合:若一个模块访问另一个模块,被访问模块的输入和输出都是数据项参数,则这两个模块为数据耦合。非直接耦合:若两个模块没有直接关系,它们之间的联系完全是通过程序的控制和调用来实现的,则称这两个模块为非直接耦合,这样的耦合独立性最强。7.下列特征中不是面向对象方法的主要特征的是_。A多态性 B标识唯一性 C封装性 D耦合性(分数:2.50)A.B.C.D. 解析:解析 面向对象
21、设计方法与面向过程设计方法有本质的不同,其基本原理是:使用现实世界的概念抽象地思考问题从而自然地解决问题。其特点包括:标识唯一性、多态性、封装性、模块独立性、继承和多态性好。8.在数据库设计中,将 E-R 图转换成关系数据模型的过程属于_。A需求分析阶段 B概念设计阶段 C逻辑设计阶段 D物理设计阶段(分数:2.50)A.B.C. D.解析:解析 逻辑结构设计的任务:概念结构是各种数据模型的共同基础,为了能够用某一 DBMS 实现用户需求,还必须将概念结构进一步转化为相应的数据模型,这正是数据库逻辑结构设计所要完成的任务。它包括从 E-R 图向关系模式转换和逻辑模式规范化及调整、实现。9.在一
22、棵二叉树上,第 5 层的结点数最多是_。A8 B9 C15 D16(分数:2.50)A.B.C.D. 解析:解析 根据二叉树的性质:二叉树第 i(i1)层上至多有 2i-1个结点。得到第 5 层的结点数最多是 16 个。10.下列有关数据库的描述,正确的是_。A数据库设计是指设计数据库管理系统B数据库技术的根本目标是要解决数据共享的问题C数据库是一个独立的系统,不需要操作系统的支持D数据库系统中,数据的物理结构必须与逻辑结构一致(分数:2.50)A.B. C.D.解析:解析 数据库设计的目的实质上是设计出满足实际应用需求的实际关系模型。数据库技术的主要目的是有效地管理和存取大量的数据资源,包括
23、:提高数据的共享性,使多个用户能够同时访问数据库中的数据;减小数据的冗余,以提高数据的一致性和完整性;提供数据与应用程序的独立性,从而减少应用程序的开发和维护代价。11.以下叙述错误的是_。AC 语言区分大小写BC 程序中的一个变量,代表内存中一个相应的存储单元,变量的值可以根据需要随时修改C整数和实数都能用 C 语言准确无误地表示出来D在 C 程序中,正整数可以用十进制、八进制和十六进制的形式来表示(分数:2.50)A.B.C. D.解析:解析 本题涉及 C 语言最基本的 3 个概念:C 语言是区分大小写的,例如,q 和 Q 是两个不同的变量;变量的实质是在内存中占据一定的存储单元,存储单元
24、里存放的是该变量的值,变量的值可以根据需要进行修改;整数在允许的范围内可以准确的表示出来,但不可能表示无限精度的实数。正整数可用二进制、十进制、八进制和十六进制表示。12.下列叙述中错误的是_。A用户所定义的标识符允许使用关键字B用户所定义的标识符应尽量做到“见名知意”C用户所定义的标识符必须以字母或下划线开头D用户定义的标识符中,大、小写字母代表不同标识(分数:2.50)A. B.C.D.解析:解析 在 C 语言中,合法标识符的命名规则是:标识符可以由字母、数字和下划线组成,并且第一个字符必须为字母或下划线,凡是要求标识符的地方都必须按此规则命名。在 C 语言的标识符中,大写字母和小写字母被
25、认为是两个不同的字符。在选择标识符时,应注意做到“见名知意”,即选择具有一定含义的英文单词或汉语拼音作为标识符,以增加程序的可读性。13.下列选项中可作为 C 语言合法常量的是_。A-80 B-080 C-8e1.0 D-80.0e(分数:2.50)A. B.C.D.解析:解析 所谓常量是指在程序运行的过程中,其值不能被改变的量。在 C 语言中,有整型常量、实型常量、字符常量和字符串常量等类型。选项 B 中是以 0 开头,表示一个八进制数,而八进制数的取值范围是 07,所以“-080”错误。在 C 语言中 e 后面的指数必须是整数,因此选项 C 和 D 也不正确。14.下列定义变量的语句中错误
26、的是_。Aint_int; Bdoubleint_; Cchar For; Dfloat US$;(分数:2.50)A.B.C.D. 解析:解析 C 语言规定,变量的标识符只能由字母、数字和下划线 3 种字符组成,且首字符必须为字母或下划线。在 C 语言中大写字母和小写字母被认为是两个不同的字符。选项 A 定义的变量标识符_int和选项 B 定义的变量标识符 int_与 C 语言的关键字 int 是不同的,是正确的变量标识。选项 C 定义的变量标识符 For 与 C 语言中的关键字 for 是两个不同的标识符,所以选项 C 是正确的,而选项 D 包含有特殊字符$,因此其不符合 C 语言的变量命
27、名规定。15.下列关于函数的叙述中正确的是_。A每个函数都可以被其他函数调用(包括 main 函数)B每个函数都可以被单独编译C每个函数都可以单独运行D在一个函数内部可以定义另一个函数(分数:2.50)A.B. C.D.解析:解析 在 C 语言中,函数定义是平行的,函数不能嵌套定义,即函数之间没有从属关系。虽然函数之间可以相互调用,但 mam 函数不能被调用,选项 A 错误:C 程序从 main 函数开始执行,当 main 数执行完毕时,整个程序就结束了。C 程序的执行必须从 mam 函数开始,选项 C 选项错误:函数不能嵌套定义,选项 D 错误。16.当 a=1、b=2、c=3、d=4 时,
28、执行下面程序段后,x 的值是_。if(ab)if(cd)x=1;elseif(ac)if(bd)x=2;else x=3;else x=6;else x=7;A1 B6 C3 D2(分数:2.50)A. B.C.D.解析:解析 本题考查的是 if.else 语句。第一个 if 语句,先判断条件,发现 ab 条件成立,执行下面的语句。第二个 if 语句,先判断条件,发现 cd 条件成立,执行下面的语句 x=1。17.以下程序的输出结果是_。#includestdio.hmain()int a=4,b=3,c=2,d=1;printf(“%d“,ab?a:dc?d:b);A1 B3 C2 D4(分
29、数:2.50)A. B.C.D.解析:解析 条件表达式的格式为:“a?b:c“,它的功能是:当 a 为真时,表达式的值等于 b 的值;当 a为假时,表达式的值等于 c 的值。因为条件运算符的结合方向为“自右向左”。因此,当表达式中嵌套使用条件表达式时,应先计算右边的条件表达式,再计算左边的条件表达式。题中应先计算“dc?d:b”的“dc”关系表达式的值,因为 d=1c=2 为真,所以取第一个表达式的值,即 d 的值作为整个表达式的值。接着计算“ab?a:d”,a=4b=3 为假,取第二个表达式的值,即 d 的值作为整个表达式的值。18.若有语句“char*line5”,下列叙述中正确的是_。A
30、定义 line 是一个数组,每个数组元素是一个基类型为 char 的指针变量B定义 line 是一个指针变量,该变量可以指向一个长度为 5 的字符型数组C定义 line 是一个指针数组,语句中的*号称为间址运算符D定义 line 是一个指向字符型函数的指针(分数:2.50)A. B.C.D.解析:解析 本题考察 C 语言中运算符的优先级,因为比*优先级高,因此 line 先与5结合,形成有5 个元素的数组 line5,然后再与 line 前面的“*”结合,表示此数组是一个指针数组,每个数组元素都是一个基类型为 char 的指针变量。19.以下程序:#includestdio.hmain()ch
31、ar str10;scanf(“%S“,printf(“%S/n“,str);运行上面的程序,输入字符串 how are you,则程序的执行结果是_。Ahow Bhow are you Ch Dhowareyou(分数:2.50)A. B.C.D.解析:解析 当从键盘输入 how are you 时,由于 scanf 输入函数的特点是遇到空格时结束读入字符,因此,该程序只将 how 这 3 个字符送到了字符数组 str 中,并在其后自动加上结束符“/0”。20.设 x 和 y 都是 int 类型,且 x=1,y=2,则 printf(“%d%d“x,y,(x,y)的输出结果是_。A12 B1
32、22 C1,2 D输出值不确定(分数:2.50)A. B.C.D.解析:解析 本题考查 printf 函数的格式和逗号表达式。printf 函数在输出时,是根据格式说明符的个数输出的,如果函数中有多余的项将不予输出;如果有输出项少于格式说明符,则出错,不能输出正确的结果。本题中逗号表达式(x,y)只返回 y 的值。此时格式说明的个数是 2,而输出项的个数是 3,因此 printf 函数只输出前两项。21.以下程序的输出结果是_。#includestdio.hmain()int a=8,b=6,m=1;switch(a%4)case 0:m+;break;case 1:m+;switch(b%3
33、)default:m+;case 0:m+;break;printf(“%d/n“,m);A1 B2 C3 D4(分数:2.50)A.B. C.D.解析:解析 本题考查 switch 语句。因为 a=8,a%4=0,所以执行 case 0 后面的语句,将 m 加 1,遇到break 语句跳出 switch。22.定义如下变量和数组:inti;int x33=1,2,3,4,5,6,7,8,9;则下面语句的输出结果是_。for(i=0;i3;i+)printf(“%d“,xi2-i);A159 B147 C357 D369(分数:2.50)A.B.C. D.解析:解析 本题主要考查二维数组的使用
34、。题中利用 for 循环来输出 x 数组中的指定元素:当 i=0 时,输出 x02=3;当 i=1 时,输出 x11=5;当 i=2 时,输出 X20=7。23.有下列程序段:typedef struct NODEint num;struct NODE*next;OLD;下列叙述中正确的是_。A以上的说明形式非法 BNODE 是一个结构体类型COLD 是一个结构体类型 DOLD 是一个结构体变量(分数:2.50)A.B.C. D.解析:解析 C 语言允许用 typedef 说明一种新类型名,其一般形式为:typedef 类型名标识符。typedef 语句的作用仅仅是用“标识符”来代表已存在的“
35、类型名”,并未产生新的数据类型,原有类型名依然有效。此题中,用使 typedef 定义了新的类型 OLD 结构,所以 OLD 为结构体类型。24.下列数组定义中错误的是_。Aint x3=0; Bint x23=1,2,3,4,5,6;Cint x3=1,2,3,4,5,6; Dint x23=1,2,3,4,5,6:(分数:2.50)A.B. C.D.解析:解析 二维数组的初始化有以下几种形式:分行进行初始化;不分行的初始化;部分数组元素初始化;省略第一维的定义,不省略第二维的定义。在选项 B 中,赋值号左边定义了一个 2 行 3 列的二维数组,而右边用 3 行 2 列的数字进行赋初值,所以
36、出现了边界的越界溢出错误。25.以下叙述错误的是_。A变量的作用域取决于变量定义语句的位置B全局变量可以在函数以外的任何部位进行定义C局部变量的作用域可用于其他函数的调用D一个变量说明为 static 存储类型是为了限制其他编译单元的引用(分数:2.50)A.B.C.D. 解析:解析 本题考查函数调用的变量作用域。全局变量不在任何函数体内定义,作用域为整个文件:局部变量在函数体内定义,作用域仅为本次函数;static 类型是静态变量,为了方便其他编译单元的引用,不能随意改变。一个函数包含两部分:函数首和函数体。函数体包括花括号内的所有语句。26.若定义函数 int*func(),则函数 fun
37、c 的返回值为_。A一个实数 B一个指向整型变量的指针C一个指向整型函数的指针 D一个整型函数的入口地址(分数:2.50)A.B. C.D.解析:解析 本题考查的是指针函数。指针函数定义的基本格式为:类型说明符*函数名()。其中,“类型说明符”表示返回的指针值所指向的数据类型。27.若有以下定义,则正确引用数组元素的是_。int a5,*p=a;A*若以下选项中所用变量都已正确定义并赋值,错误的函数调用是_。Aif(fun(x,y) Bz=fun(fun(x,y),fun(x,y);Cz=fun(fun(x,y)x,y); Dfun(x,y);(分数:2.50)A.B.C. D.解析:解析 本
38、题考查函数调用时的参数传递。选项 C 中第一个参数的表达式不正确,因此不能得到正确的结果。30.执行以下语句段后,xy 的值是_。int*pt,xy;xy=200;pt=xy=*pt+30;A200 B170 C260 D230(分数:2.50)A.B.C.D. 解析:解析 本题考查指针的运用。通过 pt=int i,k=0;for(i=0;i20;i+)ai=i;for(i=0;i4;i+)pi=for(i=0;i4;i+)k=k+*pi;printf(“%df“,k);A10 B18C6 D数组元素引用不合法,输出结果不定(分数:2.50)A.B. C.D.解析:解析 第一个 for 循环
39、,给数组 a 的 20 个元素分别赋值 019;第二个 for 循环,给数组 p 赋值,p0=a1=1,p1=a2=2,p2=a5=5,p3=a10=10;第三个 for 循环,将数组 p 中元素的值进行累加,k=1+2+5+10=18。32.下面各语句行中,能正确进行赋值字符串操作的是_。Achar s5=a,b,c,d,e; Bchar*s;gets(s);Cchar*s;s=“ABCDEF“; Dchars5;scanf(“%s“,(分数:2.50)A.B. C.D.解析:解析 本题考查赋值操作。可以采用逐个字符和字符串常量两种方式初始化一维字符数组:逐个字符初始化方式为 char s5
40、=a,b,c,d;字符串常量初始化方式为 char s5=“abcd“。33.下面程序的输出结果是_。#includestdio.hmain()char a=a,b,c,d,f,g,*p;p=a;printf(“%c/n“,*p+4);Aa Bb Ce Df(分数:2.50)A.B.C. D.解析:解析 “*”号的优先级比“+”的优先级高,所以先执行“*p”;指针 p 指向的是数组的首地址,因此*p=a,再加 4 得e。34.下面函数的功能是_。sss(s,t)char*s,*t;while(*s);while(*t)*(s+)=*(t+);return s;A将字符串 s 复制到字符串 t
41、中 B比较两个字符串的大小C求字符串的长度 D将字符串 t 续接到字符串 s 中(分数:2.50)A.B.C.D. 解析:解析 本题考查指针变量的运用。本题中的函数实质上是将字符串 t 续接到字符串 s 中。35.下列程序的运行结果是_。#includestdio.hvoid sub(int*s,int*y)static int m=4;*y=sm;m-;void main()int a=1,2,3,4,5,k;int x;printf(“/n“);for(k=0;k=4;k+)sub(a,printf(“%d,“,x);A5,4,3,2,1, B1,2,3,4,5, C0,0,0,0,0,
42、D4,4,4,4,4,(分数:2.50)A. B.C.D.解析:解析 本题考查的是静态变量以及函数的实参与形参之间的地址值传递。sub 函数中定义的变量m 是一个静态变量,系统可为其分配固定的存储空间,重复使用时,变量的值保留。所以当 main 函数中的 for 循环中语句 sub(a, Bq1=k;Cq1=q2; Dk=*q1+*q2;(分数:2.50)A.B. C.D.解析:解析 本题考查指针变量的赋值操作。选项 A 是将指针 q1 和 q2 所指向的变量值相乘,然后赋给k;选项 B 中,float 型数据和指针型数据之间不能进行赋值运算;选项 C 是两个指针变量之间的赋值;选项 D 是两
43、个指针型变量所指向的两个 int 型数据相加。37.下列程序的输出结果为_。main()union unchar*name;int age;int pay;s;s.name=“zhaoming“;s.age=32;s.pay=3000;printf(“%d/n“,s.age);A32 B3000 C0 D不确定(分数:2.50)A.B. C.D.解析:解析 本题考查的是联合体的有关概念。因为联合体是各个成员共享一段存储空间,此段存储空间最终存放的是最后存入的成员的值,所以题目中输出 s.age 实际上输出了最后存入的 3000,因为 3000已经把原来存入的 s.age (32)的值覆盖。38
44、.以下有关宏替换的叙述不正确的是_。A使用宏定义可以嵌套 B宏定义语句不进行语法检查C双引号中出现的宏名不替换 D宏名必须用大写字母表示(分数:2.50)A.B.C.D. 解析:解析 本题考查宏替换的规则。宏替换有两类:简单的字符替换和带参数的宏替换。使用宏应注意:宏定义仅仅是符号替换,不是赋值语句,因此不做语法检查;为了区别程序中其他的标示符,宏名的定义通常用大写字母,但不是必须用大写;双引号中出现的宏名不替换;使用宏定义可以嵌套,即后定义的宏中可以使用先定义的宏。39.下列程序执行输出的结果是_。#includestdio.hf(int a)int b=0;static c=3;a=c+;
45、b+;return(a);main()int a=2,i,k;for(i=0;i2;i+)k=f(a+);printf(“%d/n“,k);A3 B4 C5 D6(分数:2.50)A.B. C.D.解析:解析 由于函数 f(int a)中定义了一个静态变量 c,所以执行 for 循环 i=0 时,k=f(2)=3,之后c 的值变为 4;i=1 时,k=f(3)=4,之后 c 的值变为 5。for 循环结束,输出 k 的值为 4。40.已知函数的调用形式为“fread(buffer,size,count,fp)”,其中 buffer 代表的是_。A一个整型变量,代表要读入的数据项总数B一个文件指针,指向要读的文件C一个指针,是指向的输入数据放在内存中的起始位置D一个存储区,存放要读的数据项(分数:2.50)A.B.C. D.解析:解析 数据块输入/输出函数的调用形式为:fread(buffer,size,count,fp)。fread 函数参数说明:“buffer”是一个指针,对 fread 来说,它是读入数据的存放地址;“size”是要读写的字节数;“count”是要进行读写多少个 size 字节的数据项;“fp”是指文件型指针。