03计算机二级试题Word格式.docx

上传人:b****8 文档编号:22954435 上传时间:2023-02-06 格式:DOCX 页数:26 大小:28.37KB
下载 相关 举报
03计算机二级试题Word格式.docx_第1页
第1页 / 共26页
03计算机二级试题Word格式.docx_第2页
第2页 / 共26页
03计算机二级试题Word格式.docx_第3页
第3页 / 共26页
03计算机二级试题Word格式.docx_第4页
第4页 / 共26页
03计算机二级试题Word格式.docx_第5页
第5页 / 共26页
点击查看更多>>
下载资源
资源描述

03计算机二级试题Word格式.docx

《03计算机二级试题Word格式.docx》由会员分享,可在线阅读,更多相关《03计算机二级试题Word格式.docx(26页珍藏版)》请在冰豆网上搜索。

03计算机二级试题Word格式.docx

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

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

当前位置:首页 > 高等教育 > 农学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1