全国计算机二级C语言冲刺题.docx

上传人:b****9 文档编号:26104760 上传时间:2023-06-17 格式:DOCX 页数:24 大小:68.53KB
下载 相关 举报
全国计算机二级C语言冲刺题.docx_第1页
第1页 / 共24页
全国计算机二级C语言冲刺题.docx_第2页
第2页 / 共24页
全国计算机二级C语言冲刺题.docx_第3页
第3页 / 共24页
全国计算机二级C语言冲刺题.docx_第4页
第4页 / 共24页
全国计算机二级C语言冲刺题.docx_第5页
第5页 / 共24页
点击查看更多>>
下载资源
资源描述

全国计算机二级C语言冲刺题.docx

《全国计算机二级C语言冲刺题.docx》由会员分享,可在线阅读,更多相关《全国计算机二级C语言冲刺题.docx(24页珍藏版)》请在冰豆网上搜索。

全国计算机二级C语言冲刺题.docx

全国计算机二级C语言冲刺题

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

  1.下列数据结构中,属于非线性结构的是(  )。

  A.循环队列

  B.带链队列

  C.二叉树

  D.带链栈

  2.在面向对象方法中,实现信息隐蔽是依靠(  )。

  A.对象的继承

  B.对象的多态

  C.对象的封装

  D.对象的分类

  3.对于循环队列,下列叙述中正确的是(  )。

  A.队头指针是固定不变的

  B.队头指针一定大于队尾指针

  C.队头指针一定小于队尾指针

  D.队头指针可以大于队尾指针,也可以小于队尾指针

  4.下列叙述中,不符合良好程序设计风格的是(  )。

  A.程序的效率第一,清晰第二

  B.程序的可读性好

  C.程序中有必要的注释

  D.输人数据前要有提示信息

  5.软件设计中划分模块的一个准则是(  )。

  A.低内聚低耦合

  B.高内聚低耦合

  C.低内聚高耦合

  D.高内聚高耦合

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

  A.程序执行的效率与数据的存储结构密切相关

  B.程序执行的效率只取决于程序的控制结构

  C.程序执行的效率只取决于所处理的数据量

  D.以上三种说法都不对

  7.软件详细设计产生的图如图所示。

该图是(  )。

  A.N—S图

  B.PAD图

  C.程序流程图

  D.E—R图

  

  8.数据库管理系统是()。

  A.操作系统的一部分

  B.在操作系统支持下的系统软件

  C.一种编译系统

  D.一种操作系统

  9.在E—R图中,用来表示实体联系的图形是(  )。

  A.椭圆形

  B.矩形

  C.菱形

  D.三角形

  10.有三个关系R,S和T如下:

  

  其中关系T由关系R和S通过某种操作得到,该操作为(  )。

  A.选择

  B.投影

  C.交

  D.并

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

  A.程序设计的任务就是编写程序代码并上机调试

  B.程序设计的任务就是确定所用数据结构

  C.程序设计的任务就是确定所用算法

  D.以上三种说法都不完整

  12.以下选项中,能用做用户标识符的是(  )。

  A.void

  B_8

  C.0

  D.unsigned

  13.阅读以下程序:

  世include

  main(  )

  {intcase;floatprintF;

  printf("请输人2个数:

");

  scanf("%d%fl"&case,&printF);

  printf("%dofof\n",case,printF);

  )

  该程序在编译时产生错误,其出错原因是(  )。

  A.定义语句出错,case是关键字,不能用做用户自定义标识符

  B.定义语句出错,printF不能用做用户自定义标识符

  C.定义语句无错,scanf不能作为输入函数使用

  D.定义语句无错,printf不能输出case的值

  14.表达式:

(int)((double)9/2)-(9)%2的值是(  )。

  A.0

  B.3

  C.4

  D.5

  15.若有定义语句:

“intx=10;”,则表达式x-=x+x的值为(  )。

  A.-20

  B.-l0

  C.0

  D.10

  16.有以下程序:

  #include

  main(  )

  {inta=1,b=0;

  printf("%d,",b=a+b);

  printf("%d\n",a=2+b);‘’

  }

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

  A.0,0

  B.1,0

  C.3,2

  D.1,2

  17.设有定义:

“inta=1,b=2,C=3;”,以下语句中执行效果与其他三个不同的

  是()。

  A.if(a>b)c=a,a=b,b=C;

  B.if(a>b){c=a,a=b,b=C;}

  C.if(a>b)c=a;a=b;b=C;

  D.if(a>b){c=a;a=b.b=C;)

  18.有以下程序:

  #include

  main(  )

  {intc=0,k;

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

  switch(k)

  {default:

c+=k;

  case2:

c++;break;

  case4:

c+=2;break;

  )

  printf("%d\n",c);

  }

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

  A.3

  B.5

  C.7

  D.9

  19.以下程序段中,与语句“k—a>b?

(b>c?

1:

O):

0;”功能相同的是(  )。

  A.if(a>b)&&(b>c)k=1;elsek=0;

  B.if((a>b)‖(b>c))k=1;elsek=0;

  C.if(a<=b)k=0;elseif(b>c)k=1;

  D.if(a>b)k=1;elseif(b<=c)k=1;elsek=0:

  20.有以下程序:

  #include.

  main(  )

  {chars[]={"012xy"};inti,n=o;

  for(i=0;s[i]!

=0;i++)

  if(s[i]>=’a’&&s[i]<=’z’)n++;

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

  }

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

  A.0

  B.2

  C.3

  D.5

21.有以下程序

  #include

  main(  )

  (intn=2,k=0;

  while(k++&&n++>2);

  printf("%d%d\n",k,n);

  )

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

  A.O2

  B.13

  C.57

  D.12

  22.有以下定义语句,编译时会出现编译错误的是(  )。

  A.chara=’a’;

  B.chara=’\n’

  C.chara=’aa’;

  D.chara=’\x2d’;

  23.有以下程序

  #include

  main(  )

  {charcl,c2;

  cl=’A’+’8’-’4’

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

  printf("%C,%d\n",cl,c2);

  )

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

  A.E,69

  B.D,69

  C.E,D

  D.输出无定值

  24.有以下程序

  #include

  voidfun(intp)

  {intd=2;

  p=d++;printf("%d".p);}

  main(  )

  {inta=1;

  fun(a):

printf("%d\n",a);)

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

  A.32

  B.12

  C.21

  D.22

  25.以下函数findmax拟实现在数组中查找最大值并作为函数值返回,但程序中有错导致

  不能实现预定功能。

  #defineMIN-2147483647

  intfindmax(intx[],intn)

  {inti,max;

  for(i=0;i  {max=MIN;

  if(max  returnmax;

  )

  造成错误的原因是(  )。

  A.定义语句“inti,max;”中max未赋初值

  B.赋值语句“max=MIN;”中,不应给max赋MIN值

  C.语句“if(max  D.赋值语句“max—MIN;”放错了位置

  26.有以下程序:

  #include

  main(  )

  {intm=1,n=2,*p=&m,*q=&n,*r;

  r=P;P=q;q=r;

  printf("%d,%d,%d,%d\n",m,n,*P,*q);

  }

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

  A.1,2,1,2

  B.1,2,2,1

  C.2,1,2,1

  D.2,1,1,2

  27.若有定义语句:

"inta[4][10],*P,*q[4];"且0≤i<4,则错误的赋值是(  )。

  A.D=a

  B.q[i]=a[i]

  C.p=a[l]

  D.P=&a[2][1]

  28.有以下程序:

  #include

  #include

  main(  )

  {charstr[][20][{"One*World","One*Dream!

"},*p=str[1];

  prinft("%d,",strlen(p));printf("%s\n",p);

  )

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

  A.9,0ne*World

  B.9,0ne*Dream!

  C.10,One*Dream!

  D.10,Ome*World

  29.有以下程序

  #include

  main(  )

  {inta[]={2,3,5,4),i;

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

  switch(i%2)

  {case0:

switch(a[i]%2)

  {case0:

a[i]++;break;

  casel:

a[i]--;

  }break;

  casel:

a[i]=0;

  )

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

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

  A.3344

  B.2050

  C.3040

  D.0304

  30.有以下程序

  #include

  #include

  main(  )

  {chara[10]=”abcd”;

  printf("%d,%d\n",strlen(a),sizeof(a));

  )

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

  A.7,4

  B.4,10

  C.8,8

  D.10,10

31.下面是有关C语言字符数组的描述,其中错误的是(  )。

  A.不可以用赋值语句给字符数组名赋字符串

  B.可以用输入语句把字符串整体输入给字符数组

  C.字符数组中的内容不一定是字符串

  D.字符数组只能存放字符串

  32.下列函数的功能是(  )。

  fun(char*a,char*b).

  {while((*b=*a)!

=’\0’){a++;b++;})

  A.将a所指字符串赋给b所指空间

  B.使指针b指向a所指字符串

  C.将a所指字符串和b所指字符串进行比较

  D.检查a和b所指字符串中是否有’\O’

  33.设有以下函数:

  voidfun(intn,char*s){…}

  则下面对函数指针的定义和赋值均正确的是(  )。

  A.void(*pf)(  );pf=fun;

  B.void*pf(  );pf=fun

  C.void*pf(  );*pf=fun;

  D.void(*pf)(int,char);pf=&fun;

  34.有以下程序:

  #includedstdio.h>

  intf(intn);

  main(  )

  {inta=3,s;

  s=f(a);s=s+f(a);printf("%dkn",s);

  )

  intf(intn)

  {staticinta=1;

  n+=a++;

  returnn;

  )

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

  A.7

  B.8

  C.9

  D.10

  35.有以下程序:

  #includedstdi0.h>

  #definef(x)X*x*x

  main(  )

  {inta=3,S,t;

  s=f(a+1);t=f((a+1));

  printf("%d,%d\n",S,t);

  )

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

  A.10,64

  B.10。

10

  C.64,10

  D.64,64

  36.下面结构体的定义语句中,错误的是(  )。

  A.structord{intx;intY;intZ;};struetorda;

  B.structord{intx;inty;intZ;}structorda;

  C.structord{intX;intY;intZ;}a;

  D.struct{intX;inty;intZ;}a;

  37.设有定义:

“char*c;”,以下选项中能够使字符型指针c正确指向一个字符串的(  )。

  A.charstr[]="strin9";c=str;

  B.scanf(%s,c):

  C.c=getchar(  );

  D.*c="strin9";

  38.有以下程序:

  #include

  #include

  structA

  (inta;charb[10];doubleC;);

  structAf(structAt):

  main(  )

  {structAa={1001,"ZhangDa",l098.0};

  a=f(a);printf("%d,%S,%6.1f\n",a.a,a.b,a.c);

  )

  structAf(structAt)

  {t.a=1002;strcpy(t.b,"ChangRon9");t.c=1202.0;returnt;)

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

  A.1001,ZhangDa,1098.0

  B.1002,ZhangDa,1202.0

  C.1001,ChangRong,1098.0

  D.1002,ChangRong,1202.0

  39.若有以下程序段:

  intr=8;

  print("%d\n",r>>1):

  输出结果是()。

  A.16

  B.8

  C.4

  D.2

  40.下列关于C语言文件的叙述中正确的是(  )。

  A.文件由一系列数据依次排列组成,只能构成二进制文件

  B.文件由结构序列组成,可以构成二进制文件或文本文件

  C.文件由数据序列组成,可以构成二进制文件或文本文件

  D.文件由字符序列组成,其类型只能是文本文件

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

  请补充main(  )函数,该函数的功能是:

输入两个正整数numl和num2,求这两个数的最大公约和最小公倍数。

  例如,若输入的两个正整数为12,4,则它们的最大公约数为12,最小公倍数为4。

  注意:

部分源程序给出如下。

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

  试题程序:

  #include

  #include

  voidmain(  )

  {

  inta,b,numl,num2,t;

  system("CLS"):

  printf("\nInputtwonumbers:

\n");

  scanf("%d,%d",&numl,&num2);

  if(numl  {

  a=num2;

  b=numl:

  }

  else

  {

  a=numl;

  b=num2;

  )

  while(【1】)

  {

  t=【2】

  a=b;

  b=t:

  }

  printf(“greatestcommondivisor:

  %d\n",a);

  printf("leastcommonmultiple:

  %d\n",【3】;

  }

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

  下列给定程序中函数proc的功能是:

取出长整型变量s中偶数位上的数,依次构成一个新数放在t中。

例如,当s中的数为l23456789时,t中的数为2468。

请修改程序中的错误,使它能得出正确的结果。

  注意:

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

  试题程序:

  #include

  #include

  #include

  //****found****

  voidproc(longS,longt)

  {longsl=10;

  s/=10;

  *t=s%10;

  //****found****

  while(s  {s=s/l00;

  *t=s%10*sl+*t;

  sl=sl*10;

  }

  )

  voidmain(  )

  {longS,t;

  system("CLS"):

  printf("\nPleaseenterS:

");

  scanf("%ld",&s);

  proc(S,&t);.

  printf("Theresultis:

%ld\n",t);

  }

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

  请编写函数proc(  ),其功能是:

将str所指字符串中除下标为偶数、同时ASCIl码值为奇数的字符外,其余的字符都删除,串中剩余字符所形成的一个新串放在t所指的数组中。

例如,若str所指字符串中的内容为ABCDEFGl2345,其中字符B的ASCIl码值为偶数,所在元素的下标为奇数,因此必须删除;而字符A的ASCIl码值为奇数,所在数组中的下标为偶数,因此不应当删除。

依此类推,最后t所指的数组中的内容应是ACEG。

  注意:

部分源程序给出如下。

  请勿改动main(  )函数和其他函数中的任何内容,仅在函数proc(  )的花括号中填人所写的若干语句。

  试题程序:

  #include

  #include

  #include

  #include

  voidproc(char*str,chart[])

  {

  )

  voidmain(  )

  {

  charstr[100],t[100];

  system("CLS");

  printf("\nPleaseenterstringstr:

");

  scanf("%S",str);

  proc(str,t);

  printf("\nTheresultiS:

%s\n",t);

参考答案及解析

  一、选择题

  1.C。

【解析】线性结构是指数据元素只有一个直接前驱和直接后驱,线性表是线性结构,循环队列、带链队列和栈是指对插入和删除有特殊要求的线性表,是线性结构。

而二叉树是非线性结构。

  2.C。

【解析】对象的封装性是指从外部看只能看到对象的外部特征,即只需知道数据的取值范围和可以对该数据施加的操作,而不需要知道数据的具体结构以及实现操作的算法。

  3.D。

【解析】循环队列是把队列的头和尾在逻辑上连接起来,构成一个环。

循环队列中首尾相连,分不清头和尾,此时需要两个指示器分别指向头部和尾部。

插入就在尾部指示器的指示位置处插入,删除就在头部指示器的指示位置处删除。

  4.A。

【解析】一般来讲,程序设计风格首先应该简单和清晰,其次程序必须是可以理解的,可以概括为“清晰第一,效率第二”。

  5.B。

【解析】耦合性和内聚性是模块独立性的两个定性标准,是互相关联的。

在软件设计中,各模块间的内聚性越强,则耦合性越弱。

一般优秀的软件设计,应尽量做到高内聚,低耦合,有利于提高模块的独立性。

  6.A。

【解析】数据的存储结构、程序处理的数据量、程序的算法等都会影响程序执行效率。

  7.C。

【解析】N-S图(也被称为盒图或CHAPIN图)、PAD(问题分析图)及PFD(程序流程图)是详细设计阶段的常用工具。

E—R图即实体一联系图,是数据库设计的常用工具。

从题中图可以看出该图属于程序流程图。

  8.B。

【解析】数据库系统属于系统软件的范畴。

  9.C。

【解析】E-R图即实体一联系图(EntityRelationshipDiagram),提供了表示实体型、属性和联系的方法,是用来描述现实世界的概念模型。

构成E-R图的基本要素是实体型、属性和联系,其表示方法为:

实体型(Entity):

用矩形表示,矩形框内写明实体名;属性(Attribute):

用椭圆形表示,并用无向边将其与相应的实体连接起来;联系(Relationship):

用菱形表示,菱形框内写明联系名,并用无向边分别与有关实体连接起来,同时在无向边旁标上联系的类型(1:

1,1:

n或m:

n)。

  10.D。

【解析】关系的并运算是指由结构相同的两个关系合并,形成一个新的关系,其中包含两个关系中的所有元素。

由题可以看出,T是R和S的并运算得到的。

  11.D。

【解析】程序设计是指设计、编制、调试程序的方法和过程。

内容涉及有关的基本概念、工具、方法以及方法学等。

程序设计通常分为问题建摸、算法设计、编写代码和编译调试4个阶段。

  12.C。

【解析】标识符由字母、数字和下划线组成。

开头必须是字母或下划线且区分大小写。

在C语言中,预先定义了一些标识符,以作专门用途,称为关键字,标识符不能与关键字相同。

选项A和D是关键字,选项B是数字开头的,所以都不正确。

  13.A。

【解析】本题中定义了整形变量case,但case是关键字,关键字不能用做标识符。

单精度printF不是关键字,因为标识符区分大小写。

所以A不正确。

  14.B。

【解析】本题考查了强制类型转换。

9/2为double型,所以结果为4.5,又强制转换为整型,所以结果为4。

9%2为取余运算,结果为1。

最终结果4-1=3。

  15.B。

【解析】表达式x-=x+X可以写成x=x-(x+x),所以X的值为-l0。

  16.D。

【解析】本题输出两个值,第一个printf语句输出b的值’b=a+b=1。

第二个printf语句输出了a的值,a=2*b,此时b的值为1,所以a的值为2。

  17.C。

【解析】本题判断结果。

选项A中,如果(a>b),则执行“c=a,a=b,b=c”这个语句(注意分号的位置,如果条件成立,将会执行第一个分号前的语句),显然if不成立,则a,b,C原样输出。

选项B和选项D是同理,而选项C因为条件不成立,则不执行第一条语句“c=a”,接着执行“a=b”,将b的值赋给a,a的值为2;“b=C”,b的值为3,C的值原样输出,结果为2,3,3。

  18.A。

【解析】本题考查了switch开关语句,当表达式与某一个ease后面的常量表达式相等时,就执行case后面的语句,若没有匹配,则执行default后面的语句,各个case和default的出现次序不影响结果,执行完一个case语句,流程就转移到下一个case并继续执行。

因此在case的分支后,加break语句来跳出switch语句。

当k=1时,switch语句中没有相对应的case,所以执行default语句,此时C为1,没有遇到break语句,则执行case2,c++,此时c的值在下次使用前加1等于2,break跳出。

继续

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

当前位置:首页 > 教学研究 > 教学案例设计

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

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