当前位置:   article > 正文

C语言二级第一套题(答案+解析)_每个case后的“常量表达式”的类型应该与switch后括号内表达式的类型一致。

每个case后的“常量表达式”的类型应该与switch后括号内表达式的类型一致。

C语言二级第一套题(答案+解析)

一、选择题

  1. 一个栈的初始状态为空。现将元素1、2、3、4、5、A、B、C、D、E依次入栈,然后再依次出栈,则元素出栈的顺序是( )。

A、12345ABCDE B、EDCBA54321 C、ABCDE12345 D、54321EDCBA

【解析】栈是先进后出的原则组织数据,所以入栈最早的最后出栈,所以选择B)。

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

A、循环队列有队头和队尾两个指针,因此,循环队列是非线性结构

B、在循环队列中,只需要队头指针就能反映队列中元素的动态变化情况

C、在循环队列中,只需要队尾指针就能反映队列中元素的动态变化情况

D、循环队列中元素的个数是由队头指针和队尾指针共同决定

【解析】循环队列有队头和队尾两个指针,但是循环队列仍是线性结构的,所以A)错误;在循环队列中只需要队头指针与队尾两个指针来共同反映队列中元素的动态变化情况,所以B)与C)错误。

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

A、顺序存储结构的存储一定是连续的,链式存储结构的存储空间不一定是连续的

B、顺序存储结构只针对线性结构,链式存储结构只针对非线性结构

C、顺序存储结构能存储有序表,链式存储结构不能存储有序表

D、链式存储结构比顺序存储结构节省存储空间

【解析】链式存储结构既可以针对线性结构也可以针对非线性结构,所以B)与C)错误。链式存储结构中每个结点都由数据域与指针域两部分组成,增加了存储空间,所以D)错误。

  1. 数据流图中带有箭头的线段表示的是( )。

A、控制流B、事件驱动C、模块调用D、数据流

【解析】数据流图中带箭头的线段表示的是数据流,即沿箭头方向传送数据的通道,一般在旁边标注数据流名。

  1. 在软件开发中,需求分析阶段可以使用的工具是( )。

A、N-S图B、DFD图C、PAD图D、程序流程图

【解析】在需求分析阶段可以使用的工具有数据流图DFD图,数据字典DD,判定树与判定表,所以选择B)。

  1. 在面向对象方法中,不属于"对象"基本特点的是( )。

A、一致性B、分类性C、多态性D、标识唯一性

【解析】对象有如下一些基本特点:标识唯一性、分类性、多态性、封装性、模块独立性好。所以选择A)。

  1. 一间宿舍可住多个学生,则实体宿舍和学生之间的联系是( )。

A、一对一B、一对多C、多对一D、多对多

【解析】因为一间宿舍可以住多个学生即多个学生住在一个宿舍中,但一个学生只能住一间宿舍,所以实体宿舍和学生之间是一对多的关系。

  1. 在数据管理技术发展的三个阶段中,数据共享最好的是( )。

A、人工管理阶段B、文件系统阶段C、数据库系统阶段D、三个阶段相同

【解析】数据管理发展至今已经历了三个阶段:人工管理阶段、文件系统阶段和数据库系统阶段。其中最后一个阶段结构简单,使用方便逻辑性强物理性少,在各方面的表现都最好,一直占据数据库领域的主导地位,所以选择C)。

  1. 有三个关系R、S和T如下:

由关系R和S通过运算得到关系T,则所使用的运算为( )。

A、笛卡尔积B、交C、并D、自然连接

【解析】自然连接是一种特殊的等值连接,它要求两个关系中进行比较的分量必须是相同的属性组,并且在结果中把重复的属性列去掉,所以根据T关系中的有序组可知R与S进行的是自然连接操作。

  1. 下列叙述中错误的是( )。

A、C程序可以由多个程序文件组成 B、一个C语言程序只能实现一种算法

C、C程序可以由一个或多个函数组成 D、一个C函数可以单独作为一个C程序文件存在

【解析】在一个C语言程序中可以进行多种算法的实现,对算法的个数没有规定,所以B)错误。

12.以下选项中,能用作数据常量的是( )。

A、115L B、0118 C、1.5e1.5 D、o115

【解析】A)选项中115L表示115是长整型数据,合法。B)选项是八进制常量的表示方法,但是在八进制中不能含有数字8,所以B)错误。C)选项中e后面应该是整数不能是小数1.5,所以C)错误。D)选项中八进制常量应该是数字"0"开始,而不是字母"o"开始。

  1. 按照C语言规定的用户标识符命名规则,不能出现在标识符中的是( )。

A、大写字母 B、下划线 C、数字字符 D、连接符

【解析】C语言中标识符由字母、下划线、数字组成,且开头必须是字母或下划线。所以D)选项中的连接符不合法。

  1. 设变量已正确定义并赋值,以下正确的表达式是( )。

A、x=y+z+5,++y B、int(15.8%5) C、x=y*5=x+z D、x=25%5.0

【解析】B)与D)选项中取模运算符%的左右两个操作数均应为整数,所以B)、D)错误。C)选项中不能将x+z的值赋给表达式y*5,所以C)错误。

  1. 设有定义:int x=2;,以下表达式中,值不为6的是( )。

A、2x,x+=2 B、x++,2x C、x=(1+x) D、x=x+1

【解析】A)选项中逗号表达式先计算第一表达式2x,然后计算表达式x+=2的值,即x=x+2即4,整个逗号表达式为第二个表达式的值4,所以选A)。B)选项中首先计算逗号表达式中第一个表达式x++,此时x为3,再执行第二个表达式2x=23=6,所以逗号表达式为第二个表达式的值6。C)选项的赋值表达式可以表示为x=x(1+x)=2*(1+2)=6。D)选项中的表达式可以表示为x=x*(x+1)=2*3=6。

  1. 有以下程序:

#include <stdio.h>

main()

{ int x,y,z;

x=y=1;

z=x++,y++,++y;

printf(“%d,%d,%d\n”,x,y,z);

}

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

A、2,3,3 B、2,3,2 C、2,3,1 D、2,2,1

【解析】z=x++,y++,++y;因为赋值运算符的优先级高于逗号运算符的优先级,所以可以将上式表示成(z=x++),(y++),(++y)。然后从左向右先计算表达式z=x++,因为x++先使用后自增,所以z的值为1,x的值为2。再计算逗号表达式第二个表达式y++,此时y的值为2,最后计算第三个表达式++y,y的值为3。

  1. 有以下程序:

#include <stdio.h>

main()

{

char c1,c2;

c1=’A’+’8’-‘4’;

c2=’A’+’8’-‘5’;

printf( “%c,%d\n”,c1,c2);

}

已知字母A的ASCII码为65,程序运行后的输出结果是( )。

A、E,68 B、D,69 C、E,D D、输出无定值

【解析】本题目中字符变量c1是字符’A’的ASCII码加上4,即69所对应的字符’E’。 字符变量c2是字符’A’的ASCII码加上3,即68所对应的字符’D’。但是打印输出时,c1以%c的格式输出,所以是E,c2以%d的格式输出,所以是68。

  1. 若有定义int x,y; 并已正确给变量赋值,则以下选项中与表达式(x-y)?(x++) :(y++)中的条件表达式(x-y) 等价的是( )。

A、(x-y<0||x-y>0) B、(x-y<0) C、(x-y>0) D、(x-y==0)

【解析】条件表达式:x=表达式1?表达式2:表达式3 的含义是:先求解表达式1,若为非0(真),则求解表达式2,将表达式2的值赋给x。若表达式1的值为0(假),则求解表达式3,将表达式3的值赋给x。在本题中与表达式1:(x-y)等价的是(x-y<0||x-y>0)。

  1. 有以下程序:

#include <stdio.h>

main()

{

int x=1,y=0;

if(!x)y++;

else if(x==0)

if(x)y+=2;

else y+=3;

printf(“%d\n”,y);

}

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

A、3 B、2 C、1 D、0

【解析】 在if else语句中 else总是与离它最近的if配对。本题目中x为1所以!x为0,所以执行else if语句中的内容,判断(x==0)是否成立,因为x为1所以条件不成立,所以else if内部的if…else语句不再执行,所以y的值还是初始值0。

  1. 若有定义:float x=1.5;int a=1,b=3,c=2; 则正确的switch语句是( )。

A、

switch(a+b)

{ case 1:printf(“*\n”);

case 2+1:printf(“**\n”);}

B、

switch((int)x);

{ case 1:printf(“*\n”);

case 2:printf(“**\n”);}

C、

switch(x)

{ case 1.0:printf(“*\n”);

case 2.0:printf(“**\n”);}

D、

switch(a+b)

{ case 1:printf(“*\n”);

case c:printf(“**\n”);}

【解析】B)选项中switch((int)x);语句中不应该有最后的分号。switch(expr1),中的expr1不能用浮点类型或long类型,也不能为一个字符串,所以C)错误。case后面常量表达式的类型必须与switch后面表达式的类型一致,所以D)错误。

  1. 有以下程序:

#include <stdio.h>

main()

{ int y=9;

for(;y>0;y--)

if(y%3==0)printf(“%d”,--y);

}

程序的运行结果是( )。

A、852 B、963 C、741 D、875421

【解析】第一次for循环,y的值为9,y%3的值为0,满足条件打印 --y,即先减一后打印,所以打印8;第二次for循环,y的值为7,y%3的值为1,不执行打印语句;第三次for循环,y的值为6,y%3的值为0,满足条件打印–y,即先减一后打印,所以打印5;第四次for循环,y的值为4,不满足if条件,不执行打印语句;第五次for循环,y的值为3,满足if条件,打印输出2;第六次for循环,y的值为1,不满足条件,不执行打印语句。

  1. 有以下程序:

#include <stdio.h>

main()

{

int i,j,m=1;

for(i=1;i<3;i++)

{for(j=3;j>0;j-- )

{ if(i*j>3) break;

m=ij;}

}

printf(“m=%d\n”,m);

}

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

A、m=4 B、m=2 C、m=6 D、m=5

【解析】 第一次外循环i的值为1,第一次内循环j的值为3,不满足条件执行m=ij即m的值为3;第二次j的值为2,不满足条件执行m=ij,即m的值为6;第三次j的值为1,不满足条件执行m=ij,即m的值仍为6。第二次外循环i的值为2,j的值为3,满足条件,执行break语句,跳出循环。

  1. 有以下程序:

#include <stdio.h>

int fun(int x,int y)

{

if (x!=y) return ((x+y)/2);

else return (x);

}

main()

{

int a=4,b=5,c=6;

printf(“%d\n”,fun(2*a,fun(b,c)));

}

A、6 B、3 C、8 D、12

【解析】 本题中第一次调用为fun(8,fun(5,6)),因为fun(5,6)返回值为5,所以第二次调用为fun(8,5)=6。所以选择A)。

  1. 有以下程序:

#include <stdio.h>

int add(int a,int b){ return (a+b);}

main()

{

int k,(*f)(),a=5,b=10;

f=add;

}

则以下函数调用语句错误的是( )。

A、k=f(a,b); B、k=add(a,b); C、k=(f)(a,b); D、k=f(a,b);

【解析】D)选项中*f(a,b)表示调用后返回一个指向整型数据的地址指针,即该函数的返回值为指针类型,所以不能将其赋值给整形变量k。

  1. 有以下程序:

#include <stdio.h>

main()

{

int n,*p=NULL;

*p=&n;

printf(“Input n:”);scanf(“%d”,&p);

printf(“output n:”);printf(“%d\n”,p);

}

该程序试图通过指针p为变量n读入数据并输出,但程序有多处错误,以下语句正确的是( )

A、int n,*p=NULL;B、*p=&n;C、scanf(“%d”,&p) D、printf(“%d\n”,p);

【解析】选项B)的正确写法应为p=&n;选项C)的正确写法应为scanf(“%d”,p);选项D)的正确写法应为 printf(“%d\n”,*p)。

  1. 下列定义数组的语句中,正确的是( )。

A、#define N 10 B、int N=10; C、int x[0…10]; D、int x[ ];

int x[N]; int x[N];

【解析】数组说明的一般形式为:类型说明符 数组名 [常量表达式]。B)中N是变量,不能用变量定义数组长度。C)选项中数组长度是非法的一串数字。定义数组时必须为其指明长度,D)选项中数组长度为空,所以非法。

  1. 有以下程序:

#include <stdio.h>

main()

{ int a[]={2,3,5,4},i;

for(i=0;i<4;i++)

switch(i%2)

{

case 0:switch(a[i]%2)

​ {

​ case 0:a[i]++;break;

​ case 1:a[i]--;

​ } break;

case 1:a[i]=0;

}

for(i=0;i<4;i++) printf("%d ",a[i]);

printf(“\n”);

}

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

A、0 3 0 4 B、2 0 5 0 C、3 3 4 4 D、3 0 4 0

【解析】第一次循环i为0,i%2为0,执行switch(a[0]%2)中的case 0语句后内容即a[0]++,a[0]的值变成3;第二次循环i的值为1,i%2为1,执行case 1:a[i]=0;所以a[1]的值变成0;第三次循环i的值为2,i%2为0,执行switch(a[2]%2)中的case 1语句后的内容 a[2]–,a[2]的值变成4;第四次循环i的值为3,i%2为1,执行case 1:a[i]=0;所以a[3]的值变成0。

  1. 有以下程序:

#include <stdio.h>

main()

{

int b[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1;

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

for(j=i;j<=i;j++) t+=b[i][b[j][i]];

printf(“%d\n”,t);

}

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

A、3 B、4 C、1 D、9

【解析】每次内循环只循环一次就结束,第一次外循环时t=t+b[0][b[0][0]]=1+b[0][0]=1+0=1;第二次外循环时t=t+b[1][b[1][1]]=1+b[1][1]=1+1=2;第三次外循环时t=t+b[2][b[2][2]]=2+b[2][2]=2+2=4。

  1. 以下语句中存在语法错误的是( )。

A、char ss[6][20]; ss[1]= “right?”; B、char ss[][20]={ “right?”};

C、char *ss[6]; ss[1]= “right?”; D、char *ss[]={ “right?”};

【解析】数组定义后,不可以对数组整体赋值, s是二维数组,因ss[1]是一维字符数组,即字符串,字符串赋值可以使用strcpy(ss[1],“right”);这样的形式,而选项A)中对二维数组中的第“1”维(相当于一个一维数组)赋值,是不可以的。选项B)和D)是定义时对数组初始化,这是可以的。选项C)中,将字符串在内存中的首地址赋给指针数组的一个元素,这是可以的。

  1. 以下不能将s所指字符串正确复制到t所指存储空间的是( )

A、do{t++=s++;}while(*s ); B、for(i=0;t[i]=s[i];i++);

C、while(t=s){t++;s++} D、for(i=0,j=0;t[i++]=s[j++] 本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】

推荐阅读