03计算机二级试题Word格式.docx
《03计算机二级试题Word格式.docx》由会员分享,可在线阅读,更多相关《03计算机二级试题Word格式.docx(26页珍藏版)》请在冰豆网上搜索。
B)C语言程序仅可以解释执行
C)C语言程序既可以编译执行又可以解释执行
D)以上说法都不对
(12)以下叙述中错误的是
A)C语言的可执行程序是由一系列机器指令构成的
B)用C语言编写的源程序不能直接在计算机上运行
C)通过编译得到的二进制目标程序需要连接才可以运行
D)在没有安装C语言集成开发环境的机器上不能运行C源程序生成的.exe文件
(13)以下选项中不能用作C程序合法常量的是
A)1,234B)'
\123'
C)123D)"
\x7G"
(14)以下选项中可用作C程序合法实数的是
A).1e0B)3.0e0.2C)E9D)9.12E
(15)若有定义语句:
inta=3,b=2,c=1;
,以下选项中错误的赋值表达式是
A)a=(b=4)=3;
B)a=b=c+1;
C)a=(b=4)+c;
D)a=1+(b=c=4);
(16)有以下程序段
charname[20];
intnum;
scanf("
name=%snum=%d"
,name,&
num);
当执行上述程序段,并从键盘输入:
name=Lilinum=1001<
回车>
后,name的值为
A)LiliB)name=Lili
C)Lilinum=D)name=Lilinum=1001
(17)if语句的基本形式是:
if(表达式)语句,以下关于"
表达式"
值的叙述中正确的是
A)必须是逻辑值B)必须是整数值
C)必须是正数D)可以是任意合法的数值
(18)有以下程序
#include<
stdio.h>
main()
{intx=011;
printf("
%d\n"
,++x);
}
程序运行后的输出结果是
A)12B)11C)10D)9
(19)有以下程序
{ints;
%d"
,&
s);
while(s>
0)
{switch(s)
{case1:
,s+5);
case2:
,s+4);
break;
case3:
,s+3);
default:
,s+1);
运行时,若输入123450<
,则输出结果是
A)6566456B)66656C)66666D)6666656
(20)有以下程序段
inti,n;
for(i=0;
i<
8;
i++)
{n=rand()%5;
switch(n)
,n);
case4:
continue;
case0:
exit(0);
以下关于程序段执行情况的叙述,正确的是
A)for循环语句固定执行8次
B)当产生的随机数n为4时结束循环操作
C)当产生的随机数n为1和2时不做任何操作
D)当产生的随机数n为0时结束程序运行
(21)有以下程序
{chars[]="
012xy\08s34f4w2"
;
inti,n=0;
s[i]!
=0;
if(s[i]>
='
0'
&
s[i]<
9'
)n++;
A)0B)3C)7D)8
(22)若i和k都是int类型变量,有以下for语句
for(i=0,k=-1;
k=1;
k++)printf("
*****\n"
);
下面关于语句执行情况的叙述中正确的是
A)循环体执行两次B)循环体执行一次
C)循环体一次也不执行D)构成无限循环
(23)有以下程序
{charb,c;
inti;
b='
a'
c='
A'
6;
{if(i%2)putchar(i+b);
elseputchar(i+c);
}printf("
\n"
A)ABCDEFB)AbCdEfC)aBcDeFD)abcdef
(24)设有定义:
doublex[10],*p=x;
,以下能给数组x下标为6的元素读入数据的正确语句是
A)scanf("
%f"
x[6]);
B)scanf("
%lf"
,*(x+6));
C)scanf("
,p+6);
D)scanf("
,p[6]);
(25)有以下程序(说明:
字母A的ASCIl码值是65)
voidfun(char*s)
{while(*s)
{if(*s%2)printf("
%c"
,*s);
s++;
{chara[]="
BYTE"
fun(a);
}
A)BYB)BTC)YTD)YE
(26)有以下程序段
{…
while(getchar()!
\n'
…
以下叙述中正确的是
A)此while语句将无限循环
B)getchar()不可以出现在while语句的条件表达式中
C)当执行此while语句时,只有按回车键程序才能继续执行
D)当执行此while语句时,按任意键程序就能继续执行
(27)有以下程序
{intx=1,y=0;
if(!
x)y++;
elseif(x==0)
if(x)y+=2;
elsey+=3;
,y);
A)3B)2C)1D)0
(28)若有定义语句:
chars[3][10],(*k)[3],*p;
,则以下赋值语句正确的是
A)p=s;
B)p=k;
C)p=s[0];
D)k=s;
(29)有以下程序
voidfun(char*c)
{while(*c)
{if(*c>
&
*c<
z'
)*c=*c-('
-'
c++;
{chars[81];
gets(s);
fun(s);
puts(s);
当执行程序时从键盘上输入HelloBeijing<
,则程序的输出结果是
A)helloBeijingB)HelloBeijing
C)HELLOBEIJINGD)hELLOBeijing
(30)以下函数的功能是:
通过键盘输入数据,为数组中的所有元素赋值。
#defineN10
voidfun(intx[N])
{inti=0;
while(i<
N)scanf("
);
在程序中下划线处应填入的是
A)x+iB)&
x[i+1]
C)x+(i++)D)&
x[++i]
(31)有以下程序
{chara[30],b[30];
%s"
,a);
gets(b);
%s\n%s\n"
,a,b);
程序运行时若输入:
howareyou?
Iamfine<
则输出结果是
A)howareyou?
Iamfine
B)how
areyou?
Iamfine
C)howareyou?
Iamfine
D)howareyou?
(32)设有如下函数定义
intfun(intk)
{if(k<
1)return0;
elseif(k==1)return1;
elsereturnfun(k-1)+1;
若执行调用语句:
n=fun(3);
,则函数fun总共被调用的次数是
A)2B)3C)4D)5
(33)有以下程序
intfun(intx,inty)
{if(x!
=y)return((x+y)/2);
elsereturn(x);
{inta=4,b=5,c=6;
,fun(2*a,fun(b,c)));
A)3B)6C)8D)12
(34)有以下程序
intfun()
{staticintx=1;
x*=2;
returnx;
{inti,s=1;
for(i=1;
=3;
i++)s*=fun();
,s);
A)0B)10C)30D)64
(35)有以下程序
#defineS(x)4*(x)*x+1
{intk=5,j=2;
,S(k+3));
A)197B)143C)33D)28
(36)设有定义:
struct{charmark[12];
intnum1;
doublenum2;
}t1,t2;
,若变量均已正确赋初值,则以下语句中错误的是
A)t1=t2;
B)t2.num1=t1.num1;
C)t2.mark=t1.mark;
D)t2.num2=t1.num2;
(37)有以下程序
structord
{intx,y;
}dt[2]={1,2,3,4};
{
structord*p=dt;
%d,"
++(p->
x));
y));
A)1,2B)4,lC)3,4D)2,3
(38)有以下程序
structS
{inta,b;
}data[2]={10,100,20,200};
{structSp=data[1];
,++(p.a));
A)10B)11C)20D)21
(39)有以下程序
{unsignedchara=8,c;
c=a>
>
3;
,c);
A)32B)16C)1D)0
(40)设fp已定义,执行语句fp=fopen("
file"
"
w"
后,以下针对文本文件file操作叙述的选项中正确的是
A)写操作结束后可以从头开始读B)只能写不能读
C)可以在原有内容后追加写D)可以随意读和写
二、填空题
请将每一个空的正确答案写在答题卡序号的横线上,答在试卷上不给分。
(1)有序线性表能进行二分查找的前提是该线性表必须是【1】存储的。
(2)一棵二叉树的中序遍历结果为DBEAFC,前序遍历结果为ABDECF,则后序遍历结果为【2】。
(3)对软件设计的最小单位(模块或程序单元)进行的测试通常称为【3】测试。
(4)实体完整性约束要求关系数据库中元组的【4】属性值不能为空。
(5)在关系A(S,SN,D)和关系B(D,CN,NM)中,A的主关键字是S,B的主关键字是D,则称【5】是关系A的外码。
(6)以下程序运行后的输出结果是【6】。
{inta;
a=(int)((double)(3/2)+0.5+(int)1.99*2);
}
(7)有以下程序
{intx;
x);
if(x>
15)printf("
,x-5);
10)printf("
,x);
5)printf("
,x+5);
若程序运行时从键盘输入12<
,则输出结果为【7】。
(8)有以下程序(说明:
字符0的ASCIl码值为48)
{charc1,c2;
c1);
c2=c1+9;
%c%c\n"
,c1,c2);
若程序运行时从键盘输入48<
,则输出结果为【8】。
(9)有以下函数
voidprt(charch,intn)
{inti;
=n;
printf(i%6!
=0?
"
:
"
%c\n"
ch);
执行调用语句prt('
*'
24);
后,函数共输出了【9】行*号。
(10)以下程序运行后的输出结果是【10】。
{intx=10,y=20,t=0;
if(x==y)t=x;
x=y;
y=t;
%d%d\n"
,x,y);
(11))已知a所指的数组中有N个元素。
函数fun的功能是,将下标k(k>
0)开始的后续
元素全部向前移动一个位置。
请填空。
voidfun(inta[N],intk)
for(i=k;
N;
i++)a[【11】]=a[i];
(12)有以下程序,请在【12】处填写正确语句,使程序可正常编译运行。
【12】;
{doublex,y,(*p)();
%lf%lf"
x,&
y);
p=avg;
%f\n"
,(*p)(x,y));
doubleavg(doublea,doubleb)
{return((a+b)/2);
(13)以下程序运行后的输出结果是【13】。
#include<
{inti,n[5]={0};
=4;
{n[i]=n[i-1]*2+1;
,n[i]);
(14)以下程序运行后的输出结果是【14】。
stdlib.h>
string.h>
{char*p;
p=(char*)malloc(sizeof(char)*20);
strcpy(p,"
welcome"
for(i=6;
i>
i--)putchar(*(p+i));
free(p);
(15)以下程序运行后的输出结果是【15】。
{FILE*fp;
intx[6]={1,2,3,4,5,6},i;
fp=fopen("
test.dat"
,"
wb"
fwrite(x,sizeof(int),3,fp);
rewind(fp);
fread(x,sizeof(int),3,fp);
i++)printf("
,x[i]);
fclose(fp);
(1)A
【解析】栈是限定在一端进行插入与删除的特殊线性表。
允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);
栈底固定,而栈顶浮动。
栈按照后进先出的原则存储数据,先进入的数据被压入栈底,最后进入的数据在栈顶,需要读数据时从栈顶开始弹出数据(最后一个进入数据被第一个读出来)。
所以栈顶的元素最先被删除,本题答案为A)。
(2)B
【解析】线性结构指的是数据元素之间存在着"
一对一"
线性关系的数据结构,这样的结构中只有一个根结点,如循环链表和双向链表;
非线性结构指的是数据元素之间存在着"
一对多"
非线性关系的数据结构,这样的结构中可能有一个根结点,如树形结构,也可能有多个根结点,如网状结构。
故本题答案为B)。
(3)D
【解析】叶子结点个数=度为2的结点个数+1,在此题中叶子结点个数为1,说明度为2的结点数为0,即二叉树中不存在度为2的结点,只有度为1的结点和叶子结点,那么此二叉树就是一棵单支树,树中结点个数即为树的深度,所以答案为D)。
(4)D
【解析】软件需求规格说明书是需求分析阶段的最后成果,是软件开发中的的重要文档,故本题答案为D)。
(5)B
【解析】结构化程序设计方法主要由以下三种逻辑结构组成:
1)顺序结构:
顺序结构是一种线性、有序的结构,它依次执行各语句模块;
2)循环(重复)结构:
循环结构是重复执行一个或几个模块,直到满足某一条件为止;
3)选择(分支)结构:
选择结构是根据条件成立与否选择程序执行的通路。
(6)A
【解析】系统总体结构支持软件系统的概要设计,其他选项均正确。
故本题答案选A)。
(7)C
【解析】数据库中有三种主要程序设计语言类别的语句:
数据定义语言(DDL),数据操作语言(DML)及数据控制语言(DCL)。
其中数据操作语言主要负责数据的插入、删除、查询、修改等操作,故答案为C。
(8)D
【解析】两个实体间的联系可分为3种类型:
一对一联系、一对多联系、多对多联系。
在本题中一位教师可讲授多门课程,一门课程可由多位教师讲授,属于多对多联系。
故本题答案为D)。
(9)C
【解析】在关系代数中,除法运算可理解为笛卡尔积的逆运算。
设被除关系R为m元关系,除关系S为n元关系,那么它们的商为m-n元关系,记为R÷
S。
商的构成原则是:
将被除关系R中的m-n列,按其值分成若干组,检查每一组的n列值的集合是否包含除关系S,若包含则取m-n列的值作为商的一个元组,否则不取。
故本题答案为C)。
(10)B
【解析】无符号整型unsigned[int],占16位,范围是0~65535。
(11)A
【解析】解释程序是将源程序(如BASIC)作为输入,解释一句后就提交计算机执行一句,并不形成目标程序。
编译程序是把高级语言(如FORTRAN、COBOL、Pascal、C等)源程序作为输入,进行翻译转换,产生出机器语言的目标程序,然后再让计算机执行这个目标程序,得到计算结果。
(12)D
【解析】C语言的可执行程序是由一系列机器指令组成的,用C语言编写的源程序必须经过编译生成二进制目标代码,再经过连接才能运行,并且可以脱离C语言集成开发环境。
故答案为D)。
(13)A
【解析】常量是在程序运行过程中,其值不能被改变的量。
常量类型包括:
整型常量、实例常量、字符常量、字符串常量和符号常量。
B)选项为字符常量,表示八进制数123代表的ASCII字符;
C)选项为整型常量;
D)选项为字符串常量。
(14)A
【解析】浮点型常量有十进制小数形式和指数形式。
指数形式要求字母e(或者E)之前必须有数字,且e后面的指数必须为整数。
B)、C)、D)都是不合法的指数形式,故答案为A)。
(15)A
【解析】在A)选项中,赋值语句b=4先把4赋值给整型变量b,之后执行(b=4)=3是把常量3赋值给常量4,但是由于C语言规定赋值运算符的左侧只能是变量,不能是常量或者表达式,因此A)选项错误。
(16)A
解析】scanf()函数规定,如果在"
格式控制"
字串中除了格式说明以外还有其他字符,则在输入数据时应输入与这些字符相同的字符,如题干中的"
name="
和"
num="
。
在输入过程中遇到空格、回车或跳格键时认为输入结束,这些字符称为"
间隔符"
(17)D
【解析】if语句中的表达式可以是逻辑值也可以是任意合法的数值,表达式的运算结果为非0(真)或者0(假)。
(18)C
【解析】x=011表示把八进制的11赋值给变量x,因此x的值为十进制的9,程序运行的结果输出变量x自加运算后的十进制值,即10。
(19)A
【解析】switch语句执行完一个case后面的语句后,流程控制转移到下一个case语句继续执行,遇到break会跳出本次循环。
本题中输入1时会输出65,输入2时会输出6,输入3时会输出64,输入4时会输出5,输入5时会输出6,在输入0时不满足循环条件,程序执行结束。
(20)D
【解析】当产生的随机数n为1或2时,由于没有遇到break,因此程序将分别顺序执行case3与case