全国C语言2级考试大纲.docx

上传人:b****1 文档编号:13470106 上传时间:2023-06-14 格式:DOCX 页数:14 大小:136.37KB
下载 相关 举报
全国C语言2级考试大纲.docx_第1页
第1页 / 共14页
全国C语言2级考试大纲.docx_第2页
第2页 / 共14页
全国C语言2级考试大纲.docx_第3页
第3页 / 共14页
全国C语言2级考试大纲.docx_第4页
第4页 / 共14页
全国C语言2级考试大纲.docx_第5页
第5页 / 共14页
全国C语言2级考试大纲.docx_第6页
第6页 / 共14页
全国C语言2级考试大纲.docx_第7页
第7页 / 共14页
全国C语言2级考试大纲.docx_第8页
第8页 / 共14页
全国C语言2级考试大纲.docx_第9页
第9页 / 共14页
全国C语言2级考试大纲.docx_第10页
第10页 / 共14页
全国C语言2级考试大纲.docx_第11页
第11页 / 共14页
全国C语言2级考试大纲.docx_第12页
第12页 / 共14页
全国C语言2级考试大纲.docx_第13页
第13页 / 共14页
全国C语言2级考试大纲.docx_第14页
第14页 / 共14页
亲,该文档总共14页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

全国C语言2级考试大纲.docx

《全国C语言2级考试大纲.docx》由会员分享,可在线阅读,更多相关《全国C语言2级考试大纲.docx(14页珍藏版)》请在冰点文库上搜索。

全国C语言2级考试大纲.docx

全国C语言2级考试大纲

 

全国C语言2级考试大纲(总24页)

基本要求

   1.熟悉VisualC++集成开发环境。

   2.掌握结构化程序设计的方法,具有良好的程序设计风格。

   3.掌握程序设计中简单的数据结构和算法并能阅读简单的程序。

   4.在VisualC++集成环境下,能够编写简单的C程序,并具有基本的纠错和调试程序的能力。

   考试内容

   一、C语言程序的结构

   1.程序的构成,main函数和其他函数。

   2.头文件,数据说明,函数的开始和结束标志以及程序中的注释。

   3.源程序的书写格式。

   语言的风格。

   二、数据类型及其运算

   的数据类型(基本类型,构造类型,指针类型,无值类型)及其定义方法。

   运算符的种类、运算优先级和结合性。

   3.不同类型数据间的转换与运算。

   表达式类型(赋值表达式,算术表达式,关系表达式,逻辑表达式,条件表达式,逗号表达式)和求值规则。

   三、基本语句

   1.表达式语句,空语句,复合语句。

   2.输入输出函数的调用,正确输入数据并正确设计输出格式。

   四、选择结构程序设计

   1.用if语句实现选择结构。

   2.用switch语句实现多分支选择结构。

   3.选择结构的嵌套。

   五、循环结构程序设计

   循环结构。

   和do-while循环结构。

   语句break语句。

   4.循环的嵌套。

   六、数组的定义和引用

   1.一维数组和二维数组的定义、初始化和数组元素的引用。

   2.字符串与字符数组。

   七、函数

   1.库函数的正确调用。

   2.函数的定义方法。

   3.函数的类型和返回值。

   4.形式参数与实在参数,参数值的传递。

   5.函数的正确调用,嵌套调用,递归调用。

   6.局部变量和全局变量。

   7.变量的存储类别(自动,静态,寄存器,外部),变量的作用域和生存期。

   八、编译预处理

   1.宏定义和调用(不带参数的宏,带参数的宏)。

   2.“文件包含”处理。

   九、指针

   1.地址与指针变量的概念,地址运算符与间址运算符。

   2.一维。

二维数组和字符串的地址以及指向变量、数组、字符串、函数、结构体的指针变量的定义。

通过指针引用以上各类型数据。

   3.用指针作函数参数。

   4.返回地址值的函数。

   5.指针数组,指向指针的指针。

   十、结构体(即“结构”)与共同体(即:

“联合”)

   1.用typedef说明一个新类型。

   2.结构体和共用体类型数据的定义和成员的引用。

   3.通过结构体构成链表,单向链表的建立,结点数据的输出、删除与插入。

   十一、位运算

   1.位运算符的含义和使用。

   2.简单的位运算。

   十二、文件操作

   只要求缓冲文件系统(即高级磁盘I/O系统),对非标准缓冲文件系统(即低级磁盘I/O系统)不要求。

   1.文件类型指针(FILE类型指针)。

   2.文件的打开与关闭(fopen,fclose)。

   3.文件的读写(fputc,fgetc,fputs,fgets,fread,fwrite,fprintf,fscanf函数的应用),文件的定位(rewind,fseek函数的应用)。

   考试方式

   1.笔试:

120分钟,满分100分,其中含公共基础知识部分的30分。

   2.上机:

60分钟,满分100分。

   上机操作包括:

   

(1)填空。

   

(2)改错。

   (3)编程。

一、选择题

  

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

  A)对长度为n的有序链表进行查找,最坏清况下需要的比较次数为n

  B)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)

  C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)

  D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n)

  

(2)算法的时间复杂度是指  A)算法的执行时间  B)算法所处理的数据量  C)算法程序中的语句或指令条数  D)算法在执行过程中所需要的基本运算次数

  (3)软件按功能可以分为:

应用软件、系统软件和支撑软件(或工具软件)。

下面属于系统软件的是

  A)编辑软件

  B)操作系统  C)教务管理系统  D)浏览器

  (4)软件(程序)调试的任务是  A)诊断和改正程序中的错误  B)尽可能多地发现程序中的错误  C)发现并改正程序中的所有错误  D)确定程序中错误的性质

  (5)数据流程图(DFD图)是  A)软件概要设计的工具  B)软件详细设计的工具  C)结构化方法的需求分析工具  D)面向对象方法的需求分析工具

(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。

详细设计属于  A)定义阶段  B)开发阶段  C)维护阶段  D)上述三个阶段

  (7)数据库管理系统中负责数据模式定义的语言是  A)数据定义语言  B)数据管理语言  C)数据操纵语言  D)数据控制语言

  (8)在学生管理的关系数据库中,存取一个学生信息的数据单位是  A)文件  B)数据库  C)字段  D)记录

  (9)数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的  A)需求分析阶段  B)逻辑设计阶段  C)概念设计阶段  D)物理设计阶段

  (10)有两个关系R和T如下:

   

  则由关系K得到关系T的操作是  A)选择  B)投影  C)交  D)并

   

(11)以下叙述正确的是

  A)C语言程序是由过程和函数组成的  B)C语言函数可以嵌套调用,例如:

fun(fun(x))  C)C语言函数不可以单独编译  D)C语言中除了main函数,其他函数不可作为单独文件形式存在

  (12)以下关于C语言的叙述中正确的是  A)C语言中的注释不可以夹在变量名或关键字的中间  B)C语言中的变量可以在使用之前的任何位置进行定义  C)在C语言算术表达式的书写中,运算符两侧的运算数类型必须一致  D)C语言的数值常量中夹带空格不影响常量值的正确表示

  (13)以下C语言用户标识符中,不合法的是  A)_1  B)AaBc  C)a_b  D)a-b

  (14)若有定义:

doublea=22;inti=0,k=18;,则不符合C语言规定的赋值语句是  A)a=a++,i++;  B)i=(a+k)<=(i+k);  C)i=a%11;  D)i=!

a;

  (15)有以下程序

  #include<>  main()  {chara,b,c,d;  scanf(“%c%c”,&a,&b);  c=getchar();d=getchar();  printf(“%c%c%c%c\n”,a,b,c,d);  }  当执行程序时,按下列方式输入数据(从第1列开始,代表回车,注意:

回车也是一个字符)  12  34  则输出结果是  A)1234  B)12  C)12    3  D)12    34

(16)以i关于C语言数据类型使用的叙述中错误的是  A)若要准确无误差的表示自然数,应使用整数类型  B)若要保存带有多位小数的数据,应使用双精度类型  C)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型  D)若只处理“真”和“假”两种逻辑值,应使用逻辑类型

  (17)若a是数值类型,则逻辑表达式(a==1)||(a!

=1)的值是  A)1  B)0  C)2  D)不知道a的值,不能确定

  (18)以下选项中与if(a==1)a=b;elsea++;语句功能不同的switch语句是  A)switch(a)  {case:

a=b;break;  default:

a++;  }  B)switch(a==1)  {case0:

a=b;break;  case1:

a++;  }  C)switch(a)  {default:

a++;break;  case1:

a=b;  }  D)switch(a==1)  {case1:

a=b;break;  case0:

a++;  }

  (19)有如下嵌套的if语句  if(a

b;k=(b<c)b:

c;  B)k=(a<b)((b<c)a:

b):

((b>c)b:

c);  C)k=(a<b)((a<e)a:

e):

((b<e)b:

c);  D)k=(a<b)a:

b;k=(a<c)a:

c;

(20)有以下程序

  #include<s七>  main()  {ini,j,m=1;  for(i=1;i<3;i++)  {for(j=3;j>O;j--)  {if(i*j)>3)break;  m=i*j;  }  }  printf("m=%d\n",m);  }  程序运行后的输出结果是  A)m=6  B)m=2  C)m=4  D)m=5

  (21)有以下程序

  #include(>  main()  {inta=l;b=2;  for(;a<8;a++){b+=a;a+=2;}  printf("%d,%d\n",a,b);  }  程序运行后的输出结果是  A)9,18  B)8,11  C)7,11  D)10,14

  (22)有以下程序,其中k的初值为八进制数

  #include<>  main()  {intk=011;  printf("%d\n",k++);  }  程序运行后的输出结果是  A)12  B)11  C)10  D)9

(23)下列语句组中,正确的是  A)char*s;s="Olympic";  B)chars[7];s="Olympic";  C)char*s;s={"Olympic"};  D)chars[7];s={"Olympic"};

  (24)以下关于return语句的叙述中正确的是  A)一个自定义函数中必须有一条return语句  B)一个自定义函数中可以根据不同情况设置多条return语句  C)定义成void类型的函数中可以有带返回值的return语句  D)没有return语句的自定义函数在执行结束时不能返回到调用处

  (25)下列选项中,能正确定义数组的语句是  A)intnum[0..2008];  B)intnum[];  C)intN=2008;    intnum[N];  D)#defineN2008    intnum[N];

  (26)有以下程序

  #include<>  voidfun(char*c,intd)  {*c=*c+1;d=d+1;  printf("%c,%c,",*c,d);  main()  {charb='a',a='A';  fun(&b,a);printf("%e,%e\n",b,a);  }  程序运行后的输出结果是  A)b,B,b,A  B)b,B,B,A  C)a,B,B,a  D)a,B,a,B

(27)若有定义int(*Pt)[3];,则下列说法正确的是  A)定义了基类型为int的三个指针变量  B)定义了基类型为int的具有三个元素的指针数组pt  C)定义了一个名为*pt、具有三个元素的整型数组  D)定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组

  (28)设有定义doublea[10],*s=a;,以下能够代表数组元素a[3]的是  A)(*s)[3]  B)*(s+3)  C)*s[3]  D)*s+3

  (29)有以下程序

  #include()  main()  {inta[5]={1,2,3,4,5},b[5]={O,2,1,3,0},i,s=0;  for(i=0;i<5;i++)s=s+a[b[i]]);  printf("%d\n",s);  }  程序运行后的输出结果是  A)6  B)10  C)11  D)15

  (30)有以下程序

  #include<>  main()  {intb[3][3]={O,1,2,0,1,2,O,1,2},i,j,t=1;  for(i=0;i<3;i++)  for(j=ij<=1;j++)t+=b[i][b[j][i]];  printf("%d\n",t);  }  程序运行后的输出结果是  A)1  B)3  C)4  D)9

(31)若有以下定义和语句  chars1[10]="abcd!

",*s2="\n123\\";  printf("%d%d\n",strlen(s1),strlen(s2));  则输出结果是  A)55  B)105  C)107  D)58

  (32)有以下程序

  #include<>  #defineN8  voidfun(int*x,inti)  {*x=*(x+i);}  main()  {inta[N]={1,2,3,4,5,6,7,8},i;  fun(a,2);  for(i=O;i<N/2;i++)  {printf("%d",a[i]);}  printf("\n");  }  程序运行后的输出结果是  A)1313  B)2234  C)3234  D)1234

  (33)有以下程序

  #include<>  intf(intt[],intn);  main  {inta[4]={1,2,3,4},s;  s=f(a,4);printf("%d\n",s);  }  intf(intt[],intn)  {if(n>0)returnt[n-1]+f(t,n-1);  elsereturn0;  }  程序运行后的输出结果是  A)4  B)1O  C)14  D)6

(34)有以下程序

  #include<>  intfun()  {staticintx=1;  x*2;returnx;  }  main()  {inti,s=1,  for(i=1;i<=2;i++)s=fun();  printf("%d\n",s);  }  程序运行后的输出结果是  A)O  B)1  C)4  D)8

  (35)有以下程序

  #include<>  #defineSUB(a)(a)-(a)  main()  {inta=2,b=3,c=5,d;  d=SUB(a+b)*c;  printf("%d\n",d);  }  程序运行后的输出结果是  A)0  B)-12  C)-20  D)10

  (36)设有定义:

  structcomplex

  {intreal,unreal;}data1={1,8},data2;

  则以下赋值语句中错误的是

  A)data2=data1;

  B)data2=(2,6);

  C)=;

  D)=;

(37)有以下程序

  #include<>

  #include<>

  structA

  {inta;charb[10];doublec;};

  voidf(structAt);

  main()

  {structAa={1001,"ZhangDa",};

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

  }

  voidf(structAt)

  {=1002;strcpy(,"ChangRong");=;}

  程序运行后的输出结果是

  A)1001,zhangDa,

  B)1002,changRong,

  C)1001,ehangRong,

  D)1002,ZhangDa,

  (38)有以下定义和语句

  structworkers

  {intnum;charname[20];charc;

  struct

  {intday;intmonth;intyear;}s;

  };

  structworkersw,*pw;

  pw=&w;

  能给w中year成员赋1980的语句是

  A)*=198O;

  B)=1980;

  C)pw->year=1980;

  D)  (39)有以下程序

  #include<>  main()  {inta=2,b=2,c=2;  printf("%d\n",a/b&c);  }  程序运行后的输出结果是  A)O  B)1  C)2  D)3

(40)有以下程序

  #include<>

  main()

  {FILE*fp;charstr[10];

  fp=fopen("","w");

  fputs("abc",fp);fclose(fp);

  fpfopen("","a++");

  fprintf(fp,"%d",28);

  rewind(fp);

  fscanf(fp,"%s",str);puts(str);

  fclose(fp);

  }

  程序运行后的输出结果是

  A)abc

  B)28c  C)abc28  D)因类型不一致而出错

  二、填空题  

(1)一个队列的初始状态为空。

现将元素A,B,C,D,E,F,5,4,3,2,1依次入队,然后再依次退队,则元素退队的顺序为  【1】  。

  

(2)设某循环队列的容量为50,如果头指针front=45(指向队头元素的前一位置),尾指针rear=10(指向队尾元素),则该循环队列中共有  【2】  个元素。

  (3)设二叉树如下:

  对该二叉树进行后序遍历的结果为  【3】  。

  (4)软件是  【4】 、数据和文档的集合。

(5)有一个学生选课的关系,其中学生的关系模式为:

学生(学号,姓名,班级,年龄),课程的关系模式为:

课程(课号,课程名,学时),其中两个关系模式的键分别是学号和课号,则关系模式选课可定义为:

选课(学号,  【5】  ,成绩)。

  (6)设x为int型变量,请写出一个关系表达式  【6】  ,用以判断x同时为3和7的倍数时,关系表达式的值为真。

  (7)有以下程序

  #include<>  main()  {inta=1,b=2,c=3,d=0;  if(a==1)  if(b!

=2)  if(c==3)    d=1;  else        d=2;  elseif(c!

=3) d=3;  else     d=4;  else            d=5;  printf(“%d\n”,d);  }  程序运行后的输出结果是  【7】  。

  (8)有以下程序

  #include<>  main()  {intm,n;  scanf("%d%d",&m,&n);  while(m!

=n)  {while(m>n)m=m-n;  while(m时,输出结果是  【8】  。

(9)有以下程序

  #include<>  main()  {inti,j,a[][3]={1,2,3,4,5,6,7,8,9};  for(i=0;i<3;i++)  for(j=i;j<3;j++)printf(“%d%,a[i][j]);  printf("\n");  }  程序运行后的输出结果是  【9】  。

  (10)有以下程序

  #include<>  main()  {inta[]={1,2,3,4,5,6},*k[3],i=0;  while(i<3)  {k[i]=&a[2*i];  printf("%d",*k[i]);  i++;  }  }  程序运行后的输出结果是  【10】  。

  (11)有以下程序

  #include<>  main()  {inta[3][3]={{1,2,3},{4,5,6},{7,8,9}};  intb[3]={0},i;  for(i=0;i<3;i++)b[i]=a[i][2]+a[2][i];  for(i=0;i<3;i++)printf("%d",b[i]);  printf("\n");  }  程序运行后的输出结果是  【11】  。

(12)有以下程序

  #include<>

  #include<>  voidfun(char*str)  {chartemp;intn,i;  n=strlen(str);  temp=str[n-1];  for(i=n-1;i>0;i--)str[i]=str[i-1];  str[0]=temp;  }  main()  {chars[50];  scanf("%s",s);fun(s);printf("%s\n",s);}  程序运行后输入:

abcdef<回车>,则输出结果是  【12】  。

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

将值为三位正整数的变量x中的数值按照个位、十位、百位的顺序拆分并输出。

请填空。

  #include<>  main()  {intx=256;  printf("%d-%d-%d\n",  【13】 ,x/10%10,x/100);  }

  (14)以下程序用以删除字符串所有的空格,请填空。

  #include<>

  main()

  {chars[100]={"OurteacherteachClanguage!

"};inti,j;

  for(i=j=0;s[i]!

=’\0’;i++)  if(s[i]!

=''){s[j]=s[i];j++;}  s[j]=  【14】  printf(“%s\n”,s);  }

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

借助指针变量找出数组元素中的最大值及其元素的下标值。

请填空。

  #include<>  main()  {inta[10],*p,*s;  for(p=a;p-a<10;p++)scanf("%d",p);  for(p=a,s=a;p-a<10;p++)if(*p>*s)s=  【15】  ;  printf(“index=%d\n”,s-a);  }

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

当前位置:首页 > PPT模板 > 商务科技

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2