C语言程序设计二级样卷.docx

上传人:b****4 文档编号:3581317 上传时间:2022-11-24 格式:DOCX 页数:13 大小:23.52KB
下载 相关 举报
C语言程序设计二级样卷.docx_第1页
第1页 / 共13页
C语言程序设计二级样卷.docx_第2页
第2页 / 共13页
C语言程序设计二级样卷.docx_第3页
第3页 / 共13页
C语言程序设计二级样卷.docx_第4页
第4页 / 共13页
C语言程序设计二级样卷.docx_第5页
第5页 / 共13页
点击查看更多>>
下载资源
资源描述

C语言程序设计二级样卷.docx

《C语言程序设计二级样卷.docx》由会员分享,可在线阅读,更多相关《C语言程序设计二级样卷.docx(13页珍藏版)》请在冰豆网上搜索。

C语言程序设计二级样卷.docx

C语言程序设计二级样卷

一、选择题(

(1)~(10)、(21)~(40)每题2分,(11)~(20)每题2分,共70分)

  下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。

  

(1)下列选项中不符合良好程序设计风格的是

  A)源程序要文档化     B)数据说明的次序要规范化

  C)避免滥用goto语句  D)模块设计要保证高耦合、高内聚

  

(2)从工程管理角度,软件设计一般分为两步完成,它们是

  A)概要设计与详细设计 B)数据设计与接口设计

  C)软件结构设计与数据设计 D)过程设计与数据设计

  (3)下列选项中不属于软件生命周期开发阶段任务的是

  A)软件测试   B)概要设计C)软件维护D)详细设计

  (4)在数据库系统中,用户所见的数据模式为

  A)概念模式   B)外模式 C)内模式  D)物理模式

  (5)数据库设计的四个阶段是:

需求分析、概念设计、逻辑设计和

  A)编码设计   B)测试阶段   C)运行阶段D)物理设计

  (6)设有如下三个关系表

  下列操作中正确的是

  A)T=R∩S    B)T=R∪S

  C)T=R×S     D)T=R/S

  (7)下列叙述中正确的是

  A)一个算法的空间复杂度大,则其时间复杂度也必定大

  B)一个算法的空间复杂度大,则其时间复杂度必定小

  C)一个算法的时间复杂度大,则其空间复杂度必定小

  D)上述三种说法都不对

  (8)在长度为64的有序线性表中进行顺序查找,最坏情况下需要比较的次数为

  A)63 B)64 C)6  D)7

  (9)数据库技术的根本目标是要解决数据的

  A)存储问题B)共享问题C)安全问题D)保护问题

  (10)对下列二叉树

  进行中序遍历的结果是

  A)ACBDFEG B)ACBDFGE C)ABDCGEF D)FCADBEG

  (11)下列叙述中错误的是

  A)一个C语言程序只能实现一种算法

  B)C程序可以由多个程序文件组成

  C)C程序可以由一个或多个函数组成

  D)一个C函数可以单独作为一个C程序文件存在

  (12)下列叙述中正确的是

  A)每个C程序文件中都必须要有一个main()函数

  B)在C程序中main()函数的位置是固定的

  C)C程序中所有函数之间都可以相互调用,与函数所在位置无关

  D)在C程序的函数中不能定义另一个函数

  (13)下列定义变量的语句中错误的是

  A)int _int;      B)double int_;    C)char For;          D)float US$;

  (14)若变量x、y已正确定义并赋值,以下符合C语言语法的表达式是

  A)++x,y=x--       B)x+1=y       C)x=x+10=x+y       D)double(x)/10

  (15)以下关于逻辑运算符两侧运算对象的叙述中正确的是

  A)只能是整数0或1              B)只能是整数0或非0整数

  C)可以是结构体类型的数据       D)可以是任意合法的表达式

  (16)若有定义int x,y;并已正确给变量赋值,则以下选项中与表达式(x-y)?

(x++):

(y++)中的条件表达式(x-y)等价的是

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

  (17)有以下程序

  main()

  {int x,y,z;

  x=y=1;

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

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

  }

  程序运行后的输出结果是(逗号完成后即加1完成)

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

  (18)设有定义:

int a;   float b;   执行scanf("%2d%f",&a,&b);语句时,若从键盘输入876 543.0<回车>,a和b的值分别是

  A)876和543.000000             B)87和6.000000

  C)87和543.000000              D)76和543.000000

  (19)有以下程序

  main()

  {int a=0,b=0;

  a=10;                    /* 给a赋值

  b=20;                        给b赋值    */

  printf("a+b=%d\n",a+b);  /* 输出计算结果*/

  }

  程序运行后的输出结果是

  A)a+b=10          B)a+b=30      C)30        D)出错

  (20)在嵌套使用if语句时,C语言规定else总是

  A)和之前与其具有相同缩进位置的if配对

  B)和之前与其最近的if配对

  C)和之前与其最近的且不带else的if配对

  D)和之前的第一个if配对

  (21)下列叙述中正确的是

  A)break语句只能用于switch语句

  B)在switch语句中必须使用default

  C)break语句必须与switch语句中的case配对使用

  D)在switch语句中,不一定使用break语句

  (22)有以下程序

  main()

  {int k=5;

  while(--k) printf("%d",k-=3);

  printf("\n");

  }

  执行后的输出结果是

  A)1         B)2           C)4            D)死循环

  (23)有以下程序

  main()

  {int i;

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

  {if(i++%5==0)

  if(++i%8==0) printf("%d",i);

  }

  printf("\n");

  }

  执行后的输出结果是

  A)5           B)24           C)32           D)40

  (24)以下选项中,值为1的表达式是

  A)1–'0'        B)1-'\0'     C)'1'-0        D)'\0'-'0'

  (25)有以下程序

  fun(int x,int y){return(x+y);}

  main()

  {int a=1,b=2,c=3,sum;

  sum=fun((a++,b++,a+b),c++);

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

  }

  执行后的输出结果是

  A)6           B)7            C)8          D)9

  (26)有以下程序

  main()

  { char s[]="abcde";

  s+=2;

  printf("%d\n",s[0]);

  }

  执行后的结果是

  A)输出字符a的ASCII码        B)输出字符c的ASCII码

  C)输出字符c                   D)程序出错

  (27)有以下程序

  fun(int x,int y)

  {staticint m=0,i=2;

  i+=m+1;   m=i+x+y;   returnm;

  }

  main()

  {int j=1,m=1,k;

  k=fun(j,m);   printf("%d,",k);

  k=fun(j,m);   printf("%d\n",k);

  }

  执行后的输出结果是

  A)5,5        B)5,11           C)11,11      D)11,5

  (28)有以下程序

  fun(int x)

  {int p;

  if(x==0||x==1) return(3);

  p=x-fun(x-2);

  returnp;

  }

  main()

  { printf("%d\n",fun(7));}

  执行后的输出结果是

  A)7           B)3           C)2           D)0

  (29)在16位编译系统上,若有定义int a[]={10,20,30},*p=a;,当执行p++;后,下列说法错误的是

  A)p向高地址移了一个字节       B)p向高地址移了一个存储单元

  C)p向高地址移了两个字节       D)p与a+1等价

  (30)有以下程序

  main()

  {int a=1,b=3,c=5;

  int *p1=&a,*p2=&b,*p=&c;

  *p=*p1*(*p2);

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

  }

  执行后的输出结果是

  A)1           B)2           C)3           D)4

  (31)若有定义:

intw[3][5];,则以下不能正确表示该数组元素的表达式是

  A)*(*w+3)     B)*(w+1)[4]       C)*(*(w+1))       D)*(&w[0][0]+1)

  (32)若有以下函数首部

  int fun(double x[10],int *n)

  则下面针对此函数的函数声明语句中正确的是

  A)int fun(doublex,int*n);     B)int fun(double ,int);

  C)int fun(double*x,intn);     D)int fun(double*, int*);

  (33)有以下程序

  voidchange(intk[]){k[0]=k[5];}

  main()

  {int x[10]={1,2,3,4,5,6,7,8,9,10},n=0;

  while(n<=4) {change(&x[n]);n++;}

  for(n=0;n<5;n++) printf("%d",x[n]);

  printf("\n");

  }

  程序运行后输出的结果是

  A)678910      B)13579      C)12345      D)62345

  (34)有以下程序

  main()

  {int x[3][2]={0},i;

  for(i=0;i<3;i++)   scanf("%d",x[i]);

  printf("%3d%3d%3d\n",x[0][0],x[0][1],x[1][0]);

  }

  若运行时输入:

246<回车>,则输出结果为

  A)2 0 0     B)2 0 4     C)2 4 0     D)2 4 6

  (35)有以下程序

  intadd(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);

  (36)有以下程序

  #include   

  main(int argc,char *argv[])

  {int i=1,n=0;

  while(i

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

  }

  该程序生成的可执行文件名为:

proc.exe。

若运行时输入命令行:

  proc 123 45 67

  则程序的输出结果是

  A)3           B)5           C)7           D)11

  (37)有以下程序

  #include   

  #define   N   5

  #define   M   N+1

  #define   f(x)  (x*M)

  main()

  {int i1,i2;

  i1=f

(2);

  i2=f(1+1);

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

  }

  程序的运行结果是

  A)12 12      B)11 7       C)11 11      D)12 7

  (38)有以下结构体说明、变量定义和赋值语句

  structSTD

  {char name[10];

  int age;

  char sex;

  }s[5],*ps;

  ps=&s[0];

  则以下scanf函数调用语句中错误引用结构体变量成员的是

  A)scanf("%s",s[0].name);        B)scanf("%d",&s[0].age);

  C)scanf("%c",&(ps->sex));       D)scanf("%d",ps->age);

  (39)若有以下定义和语句

  uniondata

  { int i;  char c;  float f;}x;

  int y;

  则以下语句正确的是

  A)x=10.5;     B)x.c=101;    C)y=x;        D)printf("%d\n",x);

  (40)有以下程序

  #include 

  main()

  {FILE *fp;   int i;

  char ch[]="abcd",t;

  fp=fopen("abc.dat","wb+");

  for(i=0;i<4;i++)fwrite(&ch[i],1,1,fp);

  fseek(fp,-2L,SEEK_END);

  fread(&t,1,1,fp);

  fclose(fp);

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

  }

  程序执行后的输出结果是

  A)d           B)c           C)b           D)a

  二、填空题(每空2分,共30分)

  请将每一个空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。

  

(1)下列软件系统结构图

  的宽度为  【1】 。

  

(2)  【2】程序调试 的任务是诊断和改正程序中的错误。

  (3)一个关系表的行称为  【3】 元组 。

  (4)按“先进后出”原则组织数据的数据结构是 【4】  栈 。

  (5)数据结构分为线性结构和非线性结构,带链的队列属于  【5】 线性结构 。

  (6)设有定义:

float x=123.4567;,则执行以下语句后的输出结果是 【6】 123.460000。

  printf("%f\n",(int)(x*100+0.5)/100.0);

  (7)以下程序运行后的输出结果是 【7】1011 。

  main()

  {int m=011,n=11;

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

  }

  (8)以下程序运行后的输出结果是 【8】 。

  main()

  {int x,a=1,b=2,c=3,d=4;

  x=(a  x=(x  x=(d>x)?

x:

d;

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

  }

  (9)有以下程序,若运行时从键盘输入:

18,11<回车>,则程序的输出结果是 【9】 11。

  main()

  { int a,b;

  printf("Entera,b:

");  scanf("%d,%d",&a,&b);

  while(a!

=b)

  { while(a>b)a-=b;

  while(b>a)b-=a;

  }

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

  }

  (10)以下程序的功能是:

将输入的正整数按逆序输出。

例如:

若输入135则输出531。

请填空。

  #include  

  main()

  {int n,s;

  printf("Enteranumber:

");  scanf("%d",&n);

  printf("Output:

 ");

  do

  { s=n%10; printf("%d",s);  【10】n=n/10 ; }

  while(n!

=0);

  printf("\n");

  }

  (11)以下程序中,函数fun的功能是计算x2-2x+6,主函数中将调用fun函数计算:

  y1=(x+8)2-2(x+8)+6

  y2=sin2(x)-2sin(x)+6

  请填空。

  #include  "math.h"

  doublefun(double x){return(x*x-2*x+6);}

  main()

  {double x,y1,y2;

  printf("Enterx:

");   scanf("%lf",&x);

  y1=fun( 【11】x+8 );

  y2=fun( 【12】sin(x) );

  printf("y1=%lf,y2=%lf\n",y1,y2);

  }

  (12)下面程序的功能是:

将N行N列二维数组中每一行的元素进行排序,第0行从小到大排序,第1行从大到小排序,第2行从小到大排序,第3行从大到小排序,例如:

  #define   N   4

  voidsort(int a[][N])

  {int i,j,k,t;

  for(i=0;i

  for(j=0;j

  for(k= j+1x【13】 ;k

  /*判断行下标是否为偶数来确定按升序或降序来排序*/

  if( i%2==0&&a[i][j]>a[i][k]||(i%2!

=0&&a[i][j]

  { t=a[i][j];

  a[i][j]=a[i][k];

  a[i][k]=t;

  }

  }

  voidoutarr(int a[N][N])

  {   ……   }

  main()

  {int aa[N][N]={{2,3,4,1},{8,6,5,7},{11,12,10,9},{15,14,16,13}};

  outarr(aa);/*以矩阵的形式输出二维数组*/

  sort(aa);

  outarr(aa);

  }

  (13)下面程序的运行结果是:

【15】18  。

  #include  

  intf(int a[],int n)

  {if(n>1)

  returna[0]+f(a+1,n-1);

  else

  returna[0];

  }

  main()

  {int aa[10]={1,2,3,4,5,6,7,8,9,10},s;

  s=f(aa+2,4);   printf("%d\n",s);

  }

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

当前位置:首页 > 求职职场 > 简历

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

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