1、二级公共基础知识-92 及答案解析(总分:100.00,做题时间:90 分钟)一、单项选择题(总题数:40,分数:100.00)1.在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是_。(分数:2.50)A.逻辑设计B.需求分析C.详细设计D.物理设计2.对序线性表(23,29,34,55,60,70,78)用二分法查找值为 60的元素时,需要比较次数为_。(分数:2.50)A.1B.2C.3D.43.下列描述中,正确的是_。(分数:2.50)A.线性链表是线性表的链式存储结构B.栈与队列是非线性结构C.双向链表是非线性结构D.只有根结点的二叉树是线性结构4.开发大型软件时,产
2、生困难的根本原因是_。(分数:2.50)A.大型系统的复杂性B.人员知识不足C.客观世界千变万化D.时间紧、任务重5.两个或两个以上的模块之间关联的紧密程度称为_。(分数:2.50)A.耦合度B.内聚度C.复杂度D.连接度6.下列关于线性表的叙述中,不正确的是_。(分数:2.50)A.线性表可以是空表B.线性表是一种线性结构C.线性表的所有结点有且仅有一个前件和后件D.线性表是由 n个元素组成的一个有限序列7.设有如下关系表: R A B C 4 5 6 5 6 4 7 8 9 S A B C 4 5 6 10 9 4 T A B C 4 5 6 则下列操作正确的是_。(分数:2.50)A.T
3、=R/SB.T=RSC.T=RSD.T=RS8.以下描述中,不是线性表顺序存储结构特征的是_。(分数:2.50)A.可随机访问B.需要连续的存储空间C.不便于插入和删除D.逻辑相邻的数据物理位置上不相邻9.在三级模式之间引入两层映像,其主要功能之一是_。(分数:2.50)A.使数据与程序具有较高的独立性B.使系统具有较高的通道能力C.保持数据与程序的一致性D.提高存储空间的利用率10.下列方法中,属于使用白盒法设计测试用例的方法是_。(分数:2.50)A.错误推测B.因果图C.基本路径测试D.边界值分析11.在 C语言中,以下说法不正确的是_。(分数:2.50)A.在程序中,整数和实数都能被准
4、确无误地表示出来B.在程序中,任何一个变量名都代表存储器中的一个位置C.静态变量的生存期与整个程序的运行期相同D.语言中,任何变量都必须先声明才能进行引用12.以下关于 C语言数据类型的叙述中正确的是_。(分数:2.50)A.C语言的基本数据类型包括整型、实型、浮点型、字符型 4种B.实型常量的表达方式包括十进制形式、十六进制形式、二进制形式、八进制形式、指数形式C.若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型D.若只处理“真”和“假”两种逻辑值,应使用逻辑类型13.以下标识符不是关键字的是_。(分数:2.50)A.breakB.charC.switchD.return1
5、4.下列选项中,不能作为合法常量的是_。(分数:2.50)A.1.234e04B.1.234e0.4C.1.234e+4D.1.234e015.有以下程序: #includestdio.h main() while(getchar()!=“n“); 以下叙述中正确的是_。(分数:2.50)A.此 while语句将无限循环B.函数 getchar不可以出现在 while语句的条件表达式中C.当执行此 while语句时,只有按回车键程序才能继续执行D.当执行此 while语句时,按任意键程序就能继续执行16.下列叙述中正确的是_。(分数:2.50)A.调用 printf函数时,必须要有输出项B.使
6、用 putchar函数时,必须在之前包含头文件 stdio.hC.在语言中,整数可以以二进制、八进制或十六进制的形式输出D.调用 getchar函数读入字符时,可以从键盘上输入字符所对应的 ASCII码17.执行以下程序段后,w 的值为_。 int w=“A“,x=14,y=15; w=(x | y)B.printf(“x=%idn“,x);C.printf(“x=%dLn“,x);D.printf(“x=%ldn“,x);19.已有定义“int a=3;”和输出语句“printf(“%8x“,a);”,以下叙述正确的是_。(分数:2.50)A.整型变量的输出格式符只有%d 一种B.%x是格式
7、符的一种,它可以适用于任何一种类型的数据C.%x是格式符的一种,其变量的值按十六进制数输出,但%8x 是错误的D.%8x是正确的格式符,其中数字 8规定了输出字段的宽度20.若有定义“int x,y;”并已正确给变量赋值,则下列选项中与表达式(x-y)?(x+):(y+)中的条件表达式(x-y)等价的是_。(分数:2.50)A.(x-y0)B.(x-y0)C.(x-y0|x-y0)D.(x-y=0)21.若 a、b、c、d 都是 int型变量且都已经正确赋初值,则以下赋值语句不正确的是_。(分数:2.50)A.a+d;B.a+;C.a=b=c=d=100;D.a=(b=3)+(d=5);22.
8、有以下程序: #define F(X,Y)(X)*(Y) main() int a=3,b=4; printf(“%dn“,F(a+,b+); 程序运行后的输出结果是_。(分数:2.50)A.12B.15C.16D.2023.以下是 while语句的基本形式: while(表达式)语句; 其中“表达式” _。(分数:2.50)A.必须是逻辑表达式B.必须是关系表达式C.必须是逻辑表达式或关系表达式D.可以是任意合法的表达式24.有以下程序: #includestdio.h main() int a=6,b=7,m=1; switch(a%2) case 0:m+;break; case 1:m
9、+: switch(b%2) default:m+; case0:m+;break; printf(“%dn“,m); 程序运行后的输出结果是_。(分数:2.50)A.1B.2C.3D.425.有以下程序: #includestdio.h int fun(int a,int b) if(b=0) return a; else return(fun(-a,-b); main() printf(“%dn“,fun(4,2); 程序的运行结果是_。(分数:2.50)A.1B.2C.3D.426.关于字符常量,以下叙述正确的是_。(分数:2.50)A.空格不是一个字符常量B.字符常量能包含大于一个的字
10、符C.单引号中的大写字母和小写字母代表的是相同的字符常量D.所有的字符常量都可以作为整型量来处理27.下面函数调用语句含有实参的个数为_。 func(exp1,exp2),(exp3,exp4,exp5);(分数:2.50)A.1B.2C.3D.528.有以下程序 #includestdio.h void main() int n=2,k=1; while(!(k0|n+); printf(“%d %dn“,k,n); 程序运行后的输出结果是_。(分数:2.50)A.0 2B.1 3C.5 7D.1 229.以下定义语句不正确的是_。(分数:2.50)A.double x5=1.0,2.0,3
11、.0,4.0,5.0);B.int y5=0,1,2,3,4,5;C.char cl=“1“,“2“,“3“,“4“,“5“);D.char c2=“a“,“b“,“c“);30.若有以下定义,则对数组元素的正确引用是_。 int a5,*p=a;(分数:2.50)A.*B.char c20=“goodmoming“;C.char c=“a“,“b“,“c“,“d“;D.char c=“goodmoming“);32.下列程序的运行结果为_。 #includestdio.h void abc(char*str) int a,b,i,j; for(i=j=0;stri!=“0“;i+) if(s
12、tri!=“a“) strj+=stri; strj=“0“; void main() char str=“abcdef“; abc(str); printf(“str=%s“,str); (分数:2.50)A.str=bcdefB.str=abcdefC.str=aD.str=ab33.阅读下面程序,程序运行后的结果是_。 #include“stdio.h“ main() char*str=“abcdefghijklmnopq“; while(*str+!=“e“); printf(“%cn“,*str); (分数:2.50)AfBaCeDq34.设有如下的程序段: char str=“He
13、llo World“: char*ptr; ptr=str; 运行上面的程序段后,*(ptr+10)的值为_。(分数:2.50)A.“0“B.“0“C.不确定的值D.“0“的地址35.下述语句中,在字符串 s1和 s2相等时显示“they are Equal”的是_。(分数:2.50)A.if(*s1=*s2)puts(“they are Equal“);B.if(!strcmp(s1,s2)puts(“they are Equal“);C.if(s1=s2)Puts(“they are Equal“);D.if(strcmp(s1,s2)puts(“they are Equal“);36.设
14、有定义: Struct complex int real,unreal;datal=1,8,data2; 则以下赋值语句中错误的是_。(分数:2.50)A.data2=datal.real,datal.unreal;B.data2=(2,6);C.data2.real=datal-real;D.data2-real=datal.unreal;37.以下程序的输出结果是_。 #includestdio.h void prt(int*x,int*y,int*z) printf(“%d,%d,%dn“,+*x,+*y,*(z+); main() int a=10,b=40,c=20; prt( pr
15、t( A B C D (分数:2.50)A.B.C.D.38.设有以下说明,则叙述不正确的是_。 union un int a; char b; float c; air;(分数:2.50)A.arr所占的内存长度等于成员 c的长度B.arr的地址和它的各成员的地址都是同一地址C.arr可以作为函数参数D.不能在定义 arr时对它初始化39.若 x=4,y=5,则 x 以下叙述中正确的是_。(分数:2.50)A.此 while语句将无限循环B.函数 getchar不可以出现在 while语句的条件表达式中C.当执行此 while语句时,只有按回车键程序才能继续执行 D.当执行此 while语句
16、时,按任意键程序就能继续执行解析:解析 根据程序顺序执行的次序,当程序执行到 while这条语句,根据 while语句中的结束循环的条件是“输入回车键时,结束循环”,所以当按回车键后,程序才执行 while语句的下一条语句。16.下列叙述中正确的是_。(分数:2.50)A.调用 printf函数时,必须要有输出项B.使用 putchar函数时,必须在之前包含头文件 stdio.h C.在语言中,整数可以以二进制、八进制或十六进制的形式输出D.调用 getchar函数读入字符时,可以从键盘上输入字符所对应的 ASCII码解析:解析 选项 A,若 printf函数没有输出项,且格式字符串中不含格式
17、信息,则输出的是格式字符串本身,若格式字符串含有格式信息,运行时则出现错误提示;选项 C),在 C语言中,整数可以十进制、八进制或十六进制的形式输出;选项 D),getchar 函数是从标准输入设备读取一个字符。17.执行以下程序段后,w 的值为_。 int w=“A“,x=14,y=15; w=(x | y)B.printf(“x=%idn“,x);C.printf(“x=%dLn“,x);D.printf(“x=%ldn“,x); 解析:解析 C 语言规定,输出 long型数值的格式符为%1d。19.已有定义“int a=3;”和输出语句“printf(“%8x“,a);”,以下叙述正确的
18、是_。(分数:2.50)A.整型变量的输出格式符只有%d 一种B.%x是格式符的一种,它可以适用于任何一种类型的数据C.%x是格式符的一种,其变量的值按十六进制数输出,但%8x 是错误的D.%8x是正确的格式符,其中数字 8规定了输出字段的宽度 解析:解析 本题考查 printf函数的格式。“%8x”表示以十六进制无符号形式输出整型数据,“8”表示指定输出数据的宽度为 8位。20.若有定义“int x,y;”并已正确给变量赋值,则下列选项中与表达式(x-y)?(x+):(y+)中的条件表达式(x-y)等价的是_。(分数:2.50)A.(x-y0)B.(x-y0)C.(x-y0|x-y0) D.
19、(x-y=0)解析:解析 条件表达式的形式为:“表达式 1?表达式 2:表达式 3”。其含义为:当“表达式 1”的值为非零时,求出“表达式 2”的值,此时“表达式 2”的值就是整个条件表达式的值;当“表达式 1”的值为零时,则求“表达式 3”的值,这时“表达式 3”的值就是整个表达式的值。本题条件表达式的执行顺序是先求解表达式“x-y”的值,若其值为非 0(可以是正数,也可以是负数),则再求表达式“x+”的值,其值就是条件表达式的值;若表达式“x-y”的值为 0,则再求表达式“y+”的值,其值就是条件表达式的值。因此,本题的答案为选项 C)。21.若 a、b、c、d 都是 int型变量且都已经
20、正确赋初值,则以下赋值语句不正确的是_。(分数:2.50)A.a+d; B.a+;C.a=b=c=d=100;D.a=(b=3)+(d=5);解析:解析 C 语言规定,赋值号的右边可以是一个赋值表达式,因此选项 C)、选项 D)正确;在选项 B)中,a+是一个自加 1的表达式,a 被重新赋值,因此它是一个合法的赋值表达式;选项 A中,a+d 是一个算术表达式,虽然最后有一个分号,但这个表达式中没有赋值操作,因此它不是一条赋值语句。22.有以下程序: #define F(X,Y)(X)*(Y) main() int a=3,b=4; printf(“%dn“,F(a+,b+); 程序运行后的输出
21、结果是_。(分数:2.50)A.12 B.15C.16D.20解析:解析 此题考查的是编译预处理命令以及自加运算符。F(a+,b+)先取 a和 b的值,参加运算,再把 a和 b的值分别加 1,所以 F(a+,b+)=F(3,4)=3*4=12。23.以下是 while语句的基本形式: while(表达式)语句; 其中“表达式” _。(分数:2.50)A.必须是逻辑表达式B.必须是关系表达式C.必须是逻辑表达式或关系表达式D.可以是任意合法的表达式 解析:解析 本题考查 while表达式。while(表达式)中的表达式可以为任何合法的表达式,一般情况下为逻辑、条件表达式,需要注意的是,当等号(=
22、)误写为赋值号(=)时不会报错的,但是其值恒为 1。24.有以下程序: #includestdio.h main() int a=6,b=7,m=1; switch(a%2) case 0:m+;break; case 1:m+: switch(b%2) default:m+; case0:m+;break; printf(“%dn“,m); 程序运行后的输出结果是_。(分数:2.50)A.1B.2 C.3D.4解析:解析 本题考查 switch语句。因为 a=6,所以 a%2=0,因此第一个 switch语句,执行 case0,将m加 1,遇到 break语句跳出 switch语句,输出 m
23、值为 2。25.有以下程序: #includestdio.h int fun(int a,int b) if(b=0) return a; else return(fun(-a,-b); main() printf(“%dn“,fun(4,2); 程序的运行结果是_。(分数:2.50)A.1B.2 C.3D.4解析:解析 由程序可知,函数 fun(int a,int b)是一个递归函数。所以当主函数中调用 fun(4,2)时,其执行过程如下:fun(4,2)-fun(3,1)-fun(2,0),其返回值为 2。所以正确答案为选项 B)。26.关于字符常量,以下叙述正确的是_。(分数:2.50)
24、A.空格不是一个字符常量B.字符常量能包含大于一个的字符C.单引号中的大写字母和小写字母代表的是相同的字符常量D.所有的字符常量都可以作为整型量来处理 解析:解析 本题考查字符常量的 4个知识点:空格是一个字符常量,而且单引号中的空格不可以省略;字符常量只能包含一个字符;单引号中的大写字母和小写字母代表的是不相同的字符常量;所有的字符常量都作为整型量来处理,在计算机内部,其对应的整数值就是 ASCII码值。27.下面函数调用语句含有实参的个数为_。 func(exp1,exp2),(exp3,exp4,exp5);(分数:2.50)A.1B.2 C.3D.5解析:解析 本题考查函数调用时的实参
25、形式。这里有一个逗号运算的考查,(a,b)的运算结果为 b,因此只有一个值,结合 func的调用形式,可以知道实参的个数只有两个。28.有以下程序 #includestdio.h void main() int n=2,k=1; while(!(k0|n+); printf(“%d %dn“,k,n); 程序运行后的输出结果是_。(分数:2.50)A.0 2B.1 3C.5 7D.1 2 解析:解析 在程序中整型变量 n的初始值等于 2,整型变量 k的初始值等于 1。在执行 while语句时,由于表达式 k的值大于 0为真,所以不再需要判断 n+是否为真,(k0|n+)表达式的值为真。!(k0
26、|n+)表达式的值为假,所以 while语句中的条件不满足,循环语句不会执行,变量 n的值也不会加 1,所在输出变量 k和 n的值是 1和 2。29.以下定义语句不正确的是_。(分数:2.50)A.double x5=1.0,2.0,3.0,4.0,5.0);B.int y5=0,1,2,3,4,5; C.char cl=“1“,“2“,“3“,“4“,“5“);D.char c2=“a“,“b“,“c“);解析:解析 本题考查对一维数组的赋值。选项 B)中,y5说明数组中有 5个元素,但却给它赋了 6个值,数组溢出所以是错误的。30.若有以下定义,则对数组元素的正确引用是_。 int a5,
27、*p=a;(分数:2.50)A.* B.char c20=“goodmoming“;C.char c=“a“,“b“,“c“,“d“;D.char c=“goodmoming“);解析:解析 本题考查两个概念。用单引号括起来的一个字符常量只能存放一个字符;C 语言中没有字符串变量,只能用字符数组来存储字符串。选项 A中一个单引号内存放了若干个字符,是错误的;选项 B)和选项 D)中将一个字符串赋值给一个字符数组是允许的。32.下列程序的运行结果为_。 #includestdio.h void abc(char*str) int a,b,i,j; for(i=j=0;stri!=“0“;i+)
28、if(stri!=“a“) strj+=stri; strj=“0“; void main() char str=“abcdef“; abc(str); printf(“str=%s“,str); (分数:2.50)A.str=bcdef B.str=abcdefC.str=aD.str=ab解析:解析 本题考查函数调用是的参数传递。通过函数 abc的执行,将字符串中的字母 a去掉,保留剩下的。由于是通过指针调用,所以改变字符串的结果。33.阅读下面程序,程序运行后的结果是_。 #include“stdio.h“ main() char*str=“abcdefghijklmnopq“; whi
29、le(*str+!=“e“); printf(“%cn“,*str); (分数:2.50)Af BaCeDq解析:解析 本题考查的是取内容运算符“*”和自加运算符“+”的优先级问题。由于“+”的优先级高于“*”,所以题干中*str+!=“e“,即*(str+)!=“e“。当 str指向字符“e“时,while 循环的条件不成立,但 str已经进行了自加指向了字符“f“,所以*str 输出字符“f“。34.设有如下的程序段: char str=“Hello World“: char*ptr; ptr=str; 运行上面的程序段后,*(ptr+10)的值为_。(分数:2.50)A.“0“ B.“0
30、“C.不确定的值D.“0“的地址解析:解析 本题涉及字符数组和指针两个知识点:在 C语言中,字符数组在存放字符串时会自动在末尾加上“0“,所以题中数组 str有 11个元素;ptr 指向数组 str的首地址,ptr+10 是指向 str10,*(ptr+10)是引用 str10的值(即结束符“0“)。35.下述语句中,在字符串 s1和 s2相等时显示“they are Equal”的是_。(分数:2.50)A.if(*s1=*s2)puts(“they are Equal“);B.if(!strcmp(s1,s2)puts(“they are Equal“); C.if(s1=s2)Puts(
31、“they are Equal“);D.if(strcmp(s1,s2)puts(“they are Equal“);解析:解析 字符串比较不能用两个等号(=)来进行比较,应使用 strcmp(s1,s2)函数来比较。strcmp(s1,s2)函数的功能是:当字符串 s1和 s2相等时,返回值为 0。因此,当表达式!strcmp(s1,s2)=1时,条件成立,执行后面的语句,输出 theyare Equal。36.设有定义: Struct complex int real,unreal;datal=1,8,data2; 则以下赋值语句中错误的是_。(分数:2.50)A.data2=datal.
32、real,datal.unreal;B.data2=(2,6); C.data2.real=datal-real;D.data2-real=datal.unreal;解析:解析 本题主要考查结构体变量的定义与初始化。题目中定义了 complex类型的结构体变量data1和 data2,并对 data1进行了初始化。选项 A、选项 C)和选项 D)都是正确的,可以用一个结构体变量对另一个结构体变量赋值,用一个结构体变量的成员对另一个结构体变量的成员赋值。37.以下程序的输出结果是_。 #includestdio.h void prt(int*x,int*y,int*z) printf(“%d,%
33、d,%dn“,+*x,+*y,*(z+); main() int a=10,b=40,c=20; prt( prt( A B C D (分数:2.50)A.B. C.D.解析:解析 本题考查的是函数参数的传递及自加运算符。主函数中第一次调用函数 prt(,此函数中的输出语句 printf(“%d,%d,%dn“,+*x,+*y,*(z+);使得 a和 b的值均加 1,而*(z+)由于先执行 z+所以 c的值不变:第二次调用函数 prt( char b; float c; air;(分数:2.50)A.arr所占的内存长度等于成员 c的长度B.arr的地址和它的各成员的地址都是同一地址C.arr
34、可以作为函数参数 D.不能在定义 arr时对它初始化解析:解析 本题主要考查联合体的内存使用:联合体所占用的内存空间为最长的成员所占用的空间,int占 2字节,char 占 1字节,float 占 4字节,所以 arr所占的内存长度等于成员 c的长度:arr 的地址和它的各成员的地址都是同一地址;不能直接对 arr赋值,即不能在定义 arr时对它初始化:arr 也不可以作为函数参数。39.若 x=4,y=5,则 x&y的结果是_。(分数:2.50)A.0B.4 C.3D.5解析:解析 本题主要考查按位与运算的知识点。按位与运算是对两个运算量相应的位进行逻辑与,“&”的规则与逻辑与“&”相同。x
35、=4 的二进制为 00000100,y=5 的二进制为00000101,x&y=00000100,转化为十进制即为 4。40.下列关于 C语言数据文件的叙述中正确的是_。(分数:2.50)A.文件由 ASCII码字符序列组成,C 语言只能读写文本文件B.文件由二进制数据序列组成,C 语言只能读写二进制文件C.文件由记录序列组成,可按数据的存放形式分为二进制文件和文本文件D.文件由数据流形式组成,可按数据的存放形式分为二进制文件和文本文件 解析:解析 本题考查的是数据文件的有关概念。文件由数据流的形式组成,可以按数据存放的形式分为二进制文件和文本文件。C 语言既能读写文本文件,又能读写二进制文件。