您好,欢迎来到尔游网。
搜索
您的当前位置:首页2016年计算机二级c语言题库及答案

2016年计算机二级c语言题库及答案

来源:尔游网


2016年计算机二级c语言题库及答案

一、选择题(每小题1分,共40小题,共40分)

1.设循环队列的存储空间为Q(1:35),初始状态为front=rear=35。现经过一系列入队与退队运算后,front=15,rear=15,则循环队列中的元素个数为( )。

A.20

B.0或35

C.15

D.16

1.B。【解析】Q(1:35)则队列的存储空间为35;对空条件:front=rear(初始化时:front=rear),队满时:(rear+1)%n= =front,n为队列长度(所用数组大小),因此当执行一系列的出队与入队操作,front=rear.则队列要么为空,要么为满。

2.下列关于栈的叙述中,正确的是( )。

A.栈底元素一定是最后入栈的元素

B.栈操作遵循先进后出的原则

C.栈顶元素一定是最先入栈的元素

D.以上三种说法都不对

2.B。【解析】栈是先进后出,因此,栈底元素是先入栈的元素,栈顶元素是后入栈的元素。

3.下列链表中,其逻辑结构属于非线性结构的是( )0、

A.双向链表

B.带链的栈

C.二叉链表

D.循环链表

3.C。【解析】数据的逻辑结构是描述数据之间的关系,分两大类:线性结构和非线性结构。线性结构是n个数据元素的有序(次序)集合,指的是数据元素之间存在着“一对一”的线性关系的数据结构。常用的线性结构有:线性表,栈,队列,双队列,数组,串。非线性结构的逻辑特征是一个结点元素可能对应多个直接前驱和多个后驱。常见的非线性结构有:树(二叉树等),图(网等),广义表。

4.在关系数据库中,用来表示实体间联系的是( )。

A.网状结构

B.树状结构

C.属性

D.二维表

4.D。【解析】单一的数据结构——关系,现实世界的实体以及实体间的各种联系均用关系来表示。数据的逻辑结构——二维表,从用户角度,关系模型中数据的逻辑结构是一张二维表。但是关系模型的这种简单的数据结构能够表达丰富的语义,描述出现实世界的实体以及实体间的各种关系。

5.公司中有多个部门和多名职员,每个职员只能属于一个部门,一个部门可以有多名职员。则实体部门和职员间的联系是( )。

A.1:m联系

B.m:n联系

C.1:1联系

D.m:l联系

5.A。【解析】部门到职员是一对多的,职员到部门是多对一的,因此,实体部门和职员间的联系是l:m联系。

6.右两个关系R和S如下:

则由关系R得到关系S的操作是( )。 A.自然连接 B.并 C.选择 D.投影

6.C。【解析】选择:是在数据表中给予一定的条件进行筛选数据。投影:是把表中的某几个属性的数据选择出来。连接:有自然连接、外连接,内连接等,连接主要用于多表之间的数据查询。并:与数学中的并是一样的。两张表进行并操作,要求它们的属性个数相同并且需要相容。

7.数据字典(DD)所定义的对象都包含于( )。

A.软件结构图

B.方框图

C.数据流图(DFD图)

D.程序流程图

7.C。【解析】数据字典(DD)是指对数据的数据项、数据结构、数据

流、数据存储、处理逻辑、外部实体等进行定义和描述,其目的是对数据流程图中的各个元素做出详细的说明。

8.软件需求规格说明书的作用不包括( )。 A.软件设计的依据 B.软件可行性研究的依据 C.软件验收的依据

D.用户与开发人员对软件要做什么的共同理解

8.B。【解析】《软件可行性分析报告》是软件可行性研究的依据。

9.下面属于黑盒测试方法的是( )。

A.边界值分析

B.路径覆盖

C.语句覆盖

D.逻辑覆盖

9.A。【解析】黑盒测试方法主要有等价类划分、边界值分析、因果图、错误推测等。白盒测试的主要方法有逻辑驱动、路径测试等,主要用于软件验证。

10.下面不属于软件设计阶段任务的是( )。

A.制订软件确认测试计划

B.数据库设计

C.软件总体设计

D.算法设计

10.A。【解析】软件设计阶段的主要任务包括丙个:一是进行软件系统的可行性分析,确定软件系统的建设是否值得,能否建成。二是进行软件的系统分析,了解用户的需求,定义应用功能,详细估算开发成本和开发周期。

11.以下叙述中正确的是( )。

A.在C语言程序中,main函数必须放在其他函数的最前面

B. B.每个后缀为C的C语言源程序都可以单独进行编译

C.在C语言程序中,只有main函数才可单独进行编译

D.每个后缀为.C的C语言源程序都应该包含一个main函数

11.B。【解析】C语言是一种成功的系统描述语言,具有良好的移植性,每个后缀为.C的C语言源程序都可以单独进行编译。

12.C语言中的标识符分为关键字、预定义标识符和用户标识符,以下叙述正确的是( )。

A.预定义标识符(如库函数中的函数名)可用做用户标识符,但失去原有含义

B.用户标识符可以由字母和数字任意顺序组成

C.在标识符中大写字母和小写字母被认为是相同的字符

D.关键字可用做用户标识符,但失去原有含义

12.A。【解析】用户标识符不能以数字开头,C语言中标识符是区分大小写的,关键字不能用做用户标识符。

13.以下选项中表示一个合法的常量是(说明:符号口表示空格)( )。

A.9口9口9

B.0Xab

C.123E0.2

D.2.7e

13.B。【解析】当用指数形式表示浮点数据时,E的前后都要有数据,并且E的后面数要为整数。

14.C语言主要是借助以下哪个功能来实现程序模块化?( )

A.定义函数

C.定义常量和外部变量

D. C.三种基本结构语句

E. D.丰富的数据类型

14.A。【解析】C语言是由函数组成的,函数是C语言的基本单位。所以可以说C语言主要是借助定义函数来实现程序模块化。

15.以下叙述中错误的是( )。

A.非零的数值型常量有正值和负值的区分

B. B.常量是在程序运行过程中值不能被改变的量

C. C.定义符号常量必须用类型名来设定常量的类型

D. D.用符号名表示的常量叫符号常量

15.C。【解析】在C语言中,可以用一个标识符来表示一个常量,称之为符号常量。符号常量在使用之前必须先定义,其一般形式为:#define标识符常量。

16.若有定义和语句:int a,b;scanf(\"%d,%d\以下选项中的输人数据,不能把值3赋给变量a、5赋给变量b的是( )。

A.3,5,

B.3,5,4

C.3,5

D.3,5

16.C。【解析】在输入3和5之间除逗号外不能有其他字符。

17.C语言中char类型数据占字节数为( )。

A.3

B.4

C.1

D.2

17.C。【解析】Char类型数据占1个字节。

18.下列关系表达式中,结果为“假”的是( )。

A.(3+4)>6

B.(3!=4)>2

C.3<=4‖3

D.(3<4)=1

18.B。【解析】在一个表达式中,括号的优先级高,先计算3 !=4,为真即是l,1>2为假。

19.若以下选项中的变量全部为整型变量,且已正确定义并赋值,则语法正确的switch语句是( )。

A.switch(a+9) {case cl:y=a-b; case c2:y=a+b; }

B.switch a*b {case l0:x=a+b; default:y=a-b; }

C.switch(a+b)

{casel:case3:y=a+b;break; case0:case4:y=a-b; }

D.switch(a*a+b*b) {default:break; case 3:y=a+b;break; case 2:y=a-b;break; }

19.D。【解析】选项A,当cl和c2相等时,不成立;选项B,a*b要用括号括起来;选项C,case 与后面的数字用空格隔开。

20.有以下程序: #include main()

main()

{

int a=-2,b=0;

while(a++&&++b);

printf(\"%d,%d\\n\

}

程序运行后的输出结果是( )。

A.1,3

B.0,2

C.0,3

D.1,2

20.D。【解析】输出的结果是:-1,1 0,2 1,2

21.设有定义:int x=o,* P;,立刻执行以下语句,正确的语句是( )。

A.p=x;

B.* p=x;

C.D=NULL;

D.* p=NULL;

21.C。【解析】如果没有把P指向一个指定的值,*P是不能被赋值的。定义指针变量不赋初始值时默认为null。

22.下列叙述中正确的是( )。

A.可以用关系运算符比较字符串的大小

B. B.空字符串不占用内存,其内存空间大小是0

C. C.两个连续的单引号是合法的字符常量

D. D.两个连续的双引号是合法的字符串常量

22.D。【解析】比较两个字符串大小用函数strcomp(S,t),空字符串有结束符,所以也要占用字节,两个双引号表示的是空字符串。

23.有以下程序:

#include

main()

{

rhar a=’H’;

a=(a>=’A’&&a<=’2’)?(a-’A’+’a’):

a; printf(\"%c\\n\

}

程序运行后的输出结果是( )。

A.A

B.a

C.H

D.h

23.D。【解析】多元运算符问号前面表达式为真,所以(a-’A’+’a’)赋值给里的运算是把大写字母变成小写字母,所以答案应为选项D。

24.有以下程序:

#include

int f(int x);

main()

a,括号

{

int a,b=0;

for(a=0;a<3;a++)

{

b=b+f(a);putchar(’A’+b);

}

}

int f(int x)

{ return x * xl; }

程序运行后的输出结果是( )。

A.ABE

B.BDI

C.BCF

D.BCD

24.B。【解析】第一次循环时,b=1,输出结果为B; 第二次循环时,b=3,输出结果为D; 第三次循环时,b=8,输出结果为I。

25.设有定义:int x[2][3];,则以下关于二维数组X的叙述错误的是( )。

A.x[0]可看做是由3个整型元素组成的一维数组

B. B.x[0]和x[l]是数组名,分别代表不同的地址常量

C. C.数组X包含6个元素

D.可以用语句x[o]=0;为数组所有元素赋初值0

25.D。【解析】x[0]是不能赋值的。

26.设变量P是指针变量,语句P=NULL;是给指针变量赋NULL值,它等价于( )。

A.p=\"\";

B.p=\"0\";

C.p=0;

D.p=\";

26.C。【解析】在C语言中null等价于数字0。

27.有以下程序:

#include main()

{

int a[]={10,20,30,40},*p=a,j;

for(i=0;i<=3;i++){a[i]=*P;p++;

}

printf(\"oAd\\n\

}

程序运行后的输出结果是( )。

A.30

B.40

C.10

D.20

27.A。【解析】For循环结束后,数组a的值并没有变化,由于数组是由0开始,所以a[2]的值是30。

28.有以下程序:

#include

#define N 3

void fun(int a[][N],int b[])

{ int i,j; for(i=0;i for(j=i;j }

main()

{

int x[N][N]={1,2,3,4,5,6,7,8,9},y[N],i;

fun(x,y); for(i=0;i

}

程序运行后的输出结果是(,)。

A.2,4,8,

B.3,6,9,

C.3,5,7,

D.1,3,5,

28.B。【解析】Fun函数功能是把数组a的每一行的最大值赋给b,a的第一行的最大值是3,第二行的最大值是6,第三行的最大值是9,所以答案是3,6,9。

29.有以下程序(strcpy为字符串复制函数,strcat为字符串连接函数):

#include

#include

main()

{char a[10]=\"abc\

strcpy(a+1,b+2);

puts(strcat(a,c+1)); }

程序运行后的输出结果是( )。

A.al2xyz

B.12yz

C.a2yz

D.bc2yz

29.C。【解析】第一次执行字符串的复制函数a的值是a2,第二次执行的是字符串的连接函数,所以运行结果为a2yz。

30.以下选项中,合法的是( )。

A.char str3[]={’d’,’e’,’b’,’u’,’g’,’\\0’};

B.char str4;str4=\"hello world\";

C.char name[10];name=\"china\";

D.char strl[5]=\"pass\

30.A。【解析】选项B不能把一个字符串赋值给一个字符变量,选项c和D犯了同样的错误是把字符串赋给了数组名。

31.有以下程序:

#include main()

{ char*s=\"[2]34\";int k=0,a=0;

whil(s[k+1]!=’\\o’)

{ k++;

if(k%2=o){a=a+(s[k]-’0’+1);continue; }

a=a+(s[k]-’0’);

printf(\"k=%d a=%d\\n\

程序运行后的输出结果是( )。

A.k=6 a=11

B.k=3 a=14

C.k=4 a=12

D.k=5 a=15

31.C。【解析】输出结果:k=1 a=2 k=2 a=4 k=3 a=7 k=4 a=12

32.有以下程序:

#include main()

char a[5][10]={\"one\

int i,j;

char t:、 for(i=0;i<4;i++) for(j=i+1;j<5;j++) if(a[i][O]>a[j][0])

{t=a[i][O];a[i][O]=a[j][O];a[j][O]=t;)

puts(a[1]);

}

程序运行后的输出结果是( )。

A.fwo

B. .fix

C..two

D..owo

32.A。【解析】For循环完成的功能是把二维数组a的第一列的字母按从小到大排序,其他列的字母不变。

33.有以下程序:

#include int a=1,b=2:

void funl(int a,int b) {printf( \"%d%d\

void fun2()

{ a=3;b=4; } main()

{ funl(5,6);

fun2();

printf(\"%d%d\\n\

}

程序运行后的输出结果是( )。

A.1 2 5 6

B.5 6 3 4

C.5 6 1 2

D.3 4 5 6

33.B。【解析】Funl是输出局部变量的值,fun2是把全局变量的值改成3和4,所以输出的结果是5634。

34.有以下程序:

#include void func(int n)

{ static int num=1);

num=num+n;printf(\"%d\

}

main()

{funo(3);func(4);printf(\"n\");

}

程序运行后的输出结果是( )。

A.4 8

B.3 4

C.3 5

D.4 5

34.A。【解析】第一调用func函数时输出4,第二次调用func函数时num的值并不会释放,仍然是上次修改后的值4,第二次调用结果为8,所以输出结果是4 8。

35.有以下程序:

#include #include

void fun(int*pl,int*p2,int*s) { s=(int*)malloc(sizeof(int));

*s=*pl+*p2; free(s);

}

main()

{int a=1,b=40,*q=&a; fun(&a,&b,q);

printf(\"%d\\n\

程序运行后的输出结果是( )。

A.42

B.0

C.1

D.41

35.C。【解析】Fun函数功能是新开辟内存空间存放a和b的地址,q的地址并没有变化,所以应该还是指向地址a。

36.有以下程序: #include

struct STU

{char name[9];

char sex;

int score[2];};

void f(struct STU a[])

{ struct STU b={\"Zhao\

main()

{struct STU c[2]={{\"Qian\

f(c);

printf(”%s,%c,%d,%d,¨,c[o].name,c[o].sex,c[o].score[o],c[o].score[1]);

printf(\"%s,%c,%d,%d\\n\

}

程序运行后的输出结果是( )。

A.Zhao,m,85,90,Sun,m,98,99

B. Zhao,m,85,90,Qian,f,95,92

C..Qian,f,95,92,Sun,m,98,99

D. .Qian,f,95,92,Zhao,m,85,90

36.D。【解析】F函数是为结构体数组的第二个数赋值,数组的第一个数没有变化,所以正确答案应选D。

37.以下叙述中错误的是( )。

A.可以用typedef说明的新类型名来定义变量

B.typedef说明的新类型名必须使用大写字母,否则会出编译错误

C.用typedef可以为基本数据类型说明一个新名称

D.用typedef说明新类型的作用是用一个新的标识符来代表已存在的类型名

37.B。【解析】用typedef说明的类型不是必须用大写,而是习惯上用大写。

38.以下叙述中错误的是( )。

A.函数的返回值类型不能是结构体类型,只能是简单类型

B.函数可以返回指向结构体变量的指针

C.可以通过指向结构体变量的指针访问所指结构体变量的任何成员

D.只要类型相同,结构体变量之间可以整体赋值

38.A。【解析】函数返回值类型可以是简单类型和结构体类型。

39.若有定义语句int b=2;,则表达式(b<<2)/(3‖b)的值是( )。

A.4

B.8

C.0

D.2

39.B。【解析】2的二进制数为010,移两位后的二进制数为01000,转成十制数为8,(3||2)为真即1,8/ 1=8,所以结果为8。

40.有以下程序:

#include main()

{ FILE*fp; int i,a[6]={1,2,3,4,5,6};

fp=fopen(\"d2.dat\

for=(i=o;i<6;,i++)fpintf(fp,\"%d\\n\

rewind(fp);

for(i=0;i%6;i++)fscanf(fp,\"%d\

fclose(fp);

for(i=0;i%6;i++)printf(\"%d,\

}

程序运行后的输出结果是( )。

A.4,5,6,1,2,3,

B.1,2,3,3,2,1,

C.1,2,3,4,5,6,

D.6,5,4,3,2,1,

40.D。【解析】这个是对文件的操作,把数组的数写到文件里,然后再从文件里倒序读出。所以输出结果为6,5,4,3,2,1。

二、基本操作题(共18分)

str是一个由数字和字母字符组成的字符串,由变量num传人字符串长度。请补充函数proc(),该函数的功能是:把字符串str中的数字字符转换成数字并存放到整型数组bb中,函数返回数组bb的长度。例如,str=\"abcl23de45f967\结果为:l234567。注意:部分源程序给出如下。

请勿改动main()函数和其他函数中的任何内容,仅在函数proc()的横线上填入所编写的若干表达式或语句。

试题程序: #include #define M 80 int bb[M];

int proc(char str[],int bb[],int num) {

int i,n=0; for(i=0;i if( 【1】 ) {

bb[n]=【2】 ; n++; } }

return 【3】 ; }

void main() {

char str[M]; int num=0,n,i;

printf(\"Enter a string:\\n\"); gets(str); while(str[num]) num++:

n=proc(str,bb,num); printf(\"\\nbb=\"); for(i=0;i }

【1】str[i]>=’0’&&str[i]<=’9’【2】str[i]-’O’【3】n

【解析】题目中要求把字符串str中的数字字符转换成数字并存放到整型数组bb

中。首先,应判断字符串str中每个字符是否是数字字符。因此,【1】处填“str[i]>=’0’&&str[i]<=’9’”将每一个数字字符转化为数字放在整型数组bb中,因此,【2】处填“str[i]-’0’;由函数proc()可知,变量n中存放整型数组bb中的元素个数,最后要返回到主函数当中,因此,【3】处填’n’。

三、程序改错题(共24分)

下列给定程序中,函数proc()的功能是:读入一个字符串(长度<20),将该字符串中的所有字符按ASCIl码升序排序后输出。例如,输入opdye,则应输出deopy。请修改程序中的错误,使它能得到正确结果。

注意:不要改动main()函数,不得增行或删行,也不得更改程序的结构。试题程序:

#include%string.h>

#include%stdlib.h>

#include #include

//****found**** int proc(char str[])

{ char C; unsigned i,j;

for(i=0;i

{

c=str[j]:

//****found**** str[j]=str[i++]; str[i]=C;

}

}

void main()

{

char st/[81];

system(\"CLS\");

printf(\"\\nPlease enter a character string:\");

gets(str);

printf(\"\\nknBefore sorting:\\n %s\

proc(str);

printf(\"\\nAfter sorting decendingly:\\n %S\

}

(1)错误:int proc(char str[])

正确:void proc(char str[])

(2)错误:str[j]=str[i++];

正确:str[j]=str[i];

【解析】由主函数中的函数调用可知,函数proc()没有返回值。因此,“int proc(char str[])”应改为“void proc(char str[])”;由函数proc()可知,if语句块完成将字符串str中的第i个元素与第j个元素相交换。因此,“str[j]=str[i++];”应改为“str[j]=str[i];”。四、程序设计题 double proc(int m) { int i;

double s=0.0; //s是表示其和 for(i=1;i<=m;i++)

四、程序设计题(共18分)

请编写函数proc(),它的功能是计算:s=(In(1)4+ln(2)4+ln(3)+…+In(m))0.5 在C语

言中可调用log(n)函数求ln(n)。

例如,若m的值为30,则proc()函数值为8.0500。注意:部分源程序给出如下。

请勿改动main()函数和其他函数中的任何内容,仅在函数proc()的花括号中填人所编写的若干语句。试题程序: #include #include #inclllde #include

double proc(int m) { }

void main() {

system(\"CLS\");

printf(\"%f\\n\

【解析】由题目中所给表达式可知,表达式的值为m项表达式的和然后开平方。可以首先

通过m次循环求得m项表达式的和,然后将其和开平方并返回到主函数当中。

因篇幅问题不能全部显示,请点此查看更多更全内容

Copyright © 2019- axer.cn 版权所有 湘ICP备2023022495号-12

违法及侵权请联系:TEL:199 18 7713 E-MAIL:2724546146@qq.com

本站由北京市万商天勤律师事务所王兴未律师提供法律服务