最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

2012年9月计算机二级C语言真题及答案

来源:动视网 责编:小OO 时间:2025-09-29 17:19:48
文档

2012年9月计算机二级C语言真题及答案

2012年9月笔试真卷及答案详解第1页(共12页)2012年9月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间90分钟,满分100分)一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。(1)下列链表中,其逻辑结构属于非线性结构的是A)双向链表B)带链的栈C)二叉链表D)循环链表(2)设循环队列的存储空间为Q(1:35),初始
推荐度:
导读2012年9月笔试真卷及答案详解第1页(共12页)2012年9月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间90分钟,满分100分)一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。(1)下列链表中,其逻辑结构属于非线性结构的是A)双向链表B)带链的栈C)二叉链表D)循环链表(2)设循环队列的存储空间为Q(1:35),初始
2012年9月笔试真卷及答案详解 第1页(共12页) 

2012年9月全国计算机等级考试二级笔试试卷 

C语言程序设计 

(考试时间90分钟,满分100分) 

一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分) 

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

答在试卷上不得分。 

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

A)双向链表  B

)带链的栈 

C)二叉链表  D

)循环链表 

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

rear=15,则循环队列中的元素个数为 

A)20  B)0或35 

C)15  D)16 

(3)下列关于栈的叙述中,正确的是 

A)栈底元素一定是最后入栈的元素 B)栈操作遵循先进后出的原则 

C)栈顶元素一定是最先入栈的元素 D)以上三种说法都不对 

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

A)网状结构  B

)树状结构 

C)属性  D

)二维表 

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

间的联系是 

A)1:m联系  B

)m:n联系 

C)1:1联系  D

)m:1联系 

(6)有两个关系R和S如下: 

R                    S     

A B C  ABC 

a 1 2  c31 

b 2 1     

c 3 1     

则由关系R得到关系S的操作是 

A)自然连接 B

)并 C

)选择 D

)投影 

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

A)软件结构图  B

)方框图 

C)数据流图(DFD图)  D)程序流程图 

(8)软件需求规格说明书的作用不包括 

A)软件设计的依据   

B)软件可行性研究的依据 

C)软件验收的依据   

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

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

A)边界值分析  B

)路径覆盖 

C)语句覆盖  D

)逻辑覆盖 

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

A)制定软件确认测试计划  B)数据库设计 

C)软件总体设计  D)算法设计 

2012年9月笔试真卷及答案详解 第2页(共12页) 

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

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

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

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

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

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

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

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

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

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

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

A)9□9□9 B)0Xab C)123E0.2 D)2.7e 

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

A)定义函数  B)定义常量和外部变量 

C)三种基本结构语句  D)丰富的数据类型 

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

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

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

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

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

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

给变量b的是 

A)3,5, B)3,5,4 C)3   ,5 D)3,5 

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

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

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

A)(3+4)>6 B)(3!=4)>2 C)3<=4||3 D)(3<4)==1 

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

A)switch(a+9)  B)switch a*b 

{  case  c1:y=a-b; {  case  10:x=a+b; 

case  c1:y=a+b; default  :y=a-b; 

}                                                } 

C)switch(a+b)  D)switch (a*b+b*b) 

{  case1 : case3:y=a+b;break; {  default :break; 

case0 : case4:y=a-b; case 3:y=a+b; break; 

}                                                case 2:y=a-b; break; 

                                                } 

(20)有以下程序 

# include  

main() 

  int a=-2,b=0; 

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

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

程序运行后的输出结果是 

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

(21)设有定义:int x=0,*p;,立即执行以下语句,正确的语句是 

A)p=x; B)*p=x; C)p=NULL; D)*p=NULL; 

2012年9月笔试真卷及答案详解 第3页(共12页) 

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

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

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

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

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

(23)有以下程序 

#include  

main() 

  char a='H'; 

  a=(a>='A'&&a<='Z')?(a-'A'+'a'):a; 

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

程序运行后的输出结果是 

A)A B)a C)H D)h 

(24)有以下程序 

#include  

int f(int x); 

main() 

{ int a,b=0; 

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

  {b=b+f(a);putchar('A'+b); 

  } 

int f(int x) 

{return x*x+1;} 

程序运行后的输出结果是 

A)ABE B)BDI C)BCF D)BCD 

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

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

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

C)数组x包含6个元素 

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

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

A)p=""; B)p='0'; C)p=0; D)p=''; 

(27)有以下程序 

#include  

main() 

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

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

 printf("%d\n",a[2]); 

A)30 B)40 C)10 D)20  

(28)有以下程序 

#include  

#define N 3 

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

{  int i,j; 

for(i=0;i2012年9月笔试真卷及答案详解 第4页(共12页) 

{ b[i]=a[i][0]; 

     for(j=1;j     if(b[i]

main() 

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

fun(x,y); 

for(i=0;iprintf("\n"); 

A)2,4,8 B)3,6,9 C)3,5,7 D)1,3,5 

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

#include   

#include   

main() 

{  char a[10]="abc",b[10]="012",c[10]="xyz"; 

  strcpy(a+1,b+2); 

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

程序运行后的输出结果是 

A)a12xyz B)12yz C)a2yz D)bc2yz 

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

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

B)char str4; str4="hello world"; 

C)char name[10];  name="china"; 

D)char str1[5]= "pass",str2[6]; str2=str1; 

(31)有以下程序 

#include  

main() 

{  char *s="12134";int k=0,a=0; 

while(s[k+1]!='\0') 

{  k++; 

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

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

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

    程序运行后的输出结果是 

A)k=6 a=11 B)k=3 a=14 C)k=4 a=12 D)k=5 a=15 

(32)有以下程序 

#include  

main() 

{  char a[5][10]={"one","two","three","four","five"}; 

int i,j; 

char t; 

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

     for(j=i+1;j<5;j++) 

    if(a[i][0]>a[j][0]) 

2012年9月笔试真卷及答案详解 第5页(共12页) 

   { t=a[i][0];a[i][0]=a[j][0];a[j][0]=t;} 

  puts(a[1]); 

    程序运行后的输出结果是 

A)fwo B)fix C)two D)owo 

(33)有以下程序 

#include  

int a=1,b=2; 

void fun1(int a, int b) 

{  printf(“%d%d”,a,b);  } 

void fun2( ) 

{  a=3; b=4;  } 

main() 

{  fun1(5,6);  fun2(); 

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

    程序运行后的输出结果是 

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

(34)有以下程序 

#include  

func(int n) 

{   static int num=1; 

num=num+n;printf("%d",num); 

void main() 

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

    程序运行后的输出结果是 

A)4  8 B)3  4 C)3  5 D)4  5 

(35)有以下程序 

#include  

#include  

fun(int *p1,int *p2,int *s) 

{  s=(int*)malloc(sizeof(int)); 

*s=*p1+*p2; 

free(s); 

void main() 

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

fun(&a,&b,q); 

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

程序运行后的输出结果是 

A)42 B)0 C)1 D)41 

(36)有以下程序 

#include  

struct STU{char name[9];char sex;int score[2];}; 

void f(struct STU a[]) 

{  struct STU b={"zhao",'m',85,90}; 

a[1]=b; 

2012年9月笔试真卷及答案详解 第6页(共12页) 

main() 

{  struct STU c[2]={{"Qian",'f',95,92},{"Sun",'m',98,99}}; 

f(c); 

printf("%s,%c,%d,%d,",c[0].name,c[0].sex,c[0].score[0],c[0].score[1]); 

printf("%s,%c,%d,%d\n,",c[1].name,c[1].sex,c[1].score[0],c[1].score[1]); 

    程序运行后的输出结果是 

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 

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

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

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

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

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

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

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

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

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

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

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

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

(40)有以下程序 

#include  

main() 

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

fp=fopen("d2.dat","w+"); 

for(i=0;i<6;i++) fprintf(fp,"%d\n",a[i]); 

rewind(fp); 

for(i=0;i<6;i++) fscanf(fp,"%d",&a[5-i]); 

fclose(fp); 

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

程序运行后的输出结果是 

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 

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

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

(1)一棵二叉树共有47个结点,其中有23个度为2的结点。假设根结点在第1层,则该二叉树的深度为  【1】  。

 

(2)设栈的存储空间为S(1:40),初始状态为bottom=0,top=0,现经过一系列入栈与出栈运算后,top=20,则

当前栈中有  【2】  个元素。 

(3)数据性分为逻辑性和物理性。当总体逻辑结构改变时,其局部逻辑结构可以不变,从而根据局

部逻辑结构编写的应用程序不必修改,称为  【3】  。 

(4)关系数据库中能实现的专门关系运算包括  【4】  、连接和投影。 

(5)软件按功能通常可以分为应用软件、系统软件和支撑软件(或工具软件)。Unix操作系统属于  【5】  软

件。 

(6)请写出与 !(a<=b)等价的C语言表达式  【6】  。 

(7)以下程序运行时从键盘输入:1.0  2.0,输出结果是:1.000000  2.000000,请填空。 

#include  

2012年9月笔试真卷及答案详解 第7页(共12页) 

main() 

{  double a;  float b; 

scanf(“  【7】  ”,&a,&b);  printf("%f%f \n",a,b); 

(8)有以下程序 

#include  

main() 

{  int n1=0,n2=0,n3=0;   char ch; 

while((ch=getchar())!='!') 

   switch(ch) 

   {  case '1':case '3':   n1++;break; 

 

      case '2':case '4':   n2++;break; 

default       :  n3++;break; 

   } 

printf("%d%d%d\n",n1,n2,n3); 

若程序运行时输入01234567!<回车>,则输出结果是  【8】  。 

(9)有以下程序 

#include  

main() 

{  int i,sum=0; 

for(i=1;i<9;i+=2)sum+=i; 

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

程序运行后的输出结果是  【9】  。 

(10)有以下程序 

#include  

main() 

{   int d,n=1234; 

while(n!=0) 

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

程序运行后的输出结果是【10】  。 

(11)有以下程序 

#include  

int k=7; 

int *st(int *a) 

{  int *c=&k; 

if(*a>*c)c=a; 

return c; 

main() 

{  int i=3,*p=&i,*r; 

r=st(p);printf("%d\n",*r); 

程序运行后的输出结果是  【11】  。 

(12)以下程序的输出结果是  【12】   

#include  

2012年9月笔试真卷及答案详解 第8页(共12页) 

#define N 3 

#define M(n) (N+1)*n 

main() 

{  int x; 

x=2*(N+M(2)); 

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

(13)若有定义语句:char str[]="0";,则字符串str在内存中实际占【13】  字节。 

(14)有以下程序 

#include  

int fun(int n) 

{  if(n==0)return(1); 

return(fun(n-1*n)); 

main() 

{  int t; 

t=fun(3);  printf("%d\n",t); 

程序运行后的输出结果是【14】  。 

(15)以下函数的功能是输出链表结点中的数据,形参指针h已指向如下链表 

h

 A 

 

B

 

C\0

请填空。 

struct slist{ char data;  struct slist  *next}; 

void fun(struct slist *h) 

{  struct slist  *p; 

   p=h; 

   while(p) 

   { printf("%c  ",p->data);p=  【15】  ; } 

printf("\n"); 

2012年9月笔试真卷及答案详解 第9页(共12页) 

2012年9月全国计算机等级考试 

二级C语言程序设计答案及详解 

一、选择题 

(1)C) 【解析】二叉链表作为树的存储结构。链表中结点的两个链域分别指向该结点的第一个孩子

结点和下一个兄弟结点。 

(2)B) 【解析】循环队列的当前指针和尾指针都等于15,此循环队列中元素的个数有两种情况,

第一种情况是当前指针和尾指针都是第一次到达15,此时元素个数为0;第二种情况是当前指针第一次到达15,

而尾指针第二次到达15,此时元素个数为35。 

(3)B) 【解析】栈是限定只能在表的一端进行插入和删除操作的线性表,必须按“后进先出”的规

则操作元素。 

(4)D) 【解析】在关系数据库中,实体间的联系由一个二维表来表示。  

(5)A) 【解析】一个部门可以有多名员工,所以实体部门和职员间的联系是1:m联系。 

(6)C) 【解析】关系S是由关系R中的一行元组组成,应通过选择运算得到。 

(7)C) 【解析】数据字典是指对数据的数据项、数据结构、数据流、数据存储、处理逻辑、外部实

体等进行定义和描述,其目的是对数据流程图中的各个元素做出详细的说明。 

(8)B) 【解析】软件规格说明书主要有三个作用:①用户和软件开发人员之间的合同;②开发人员

进行设计和编程的依据;③软件工程项目验收的依据。   

(9)A) 【解析】采用黑盒技术设计测试用例的方法有:等价类划分、边界值分析、错误推测、因果

图和综合策略。 

(10)A) 【解析】软件设计阶段总体分为两部分:概要设计和详细设计,此阶段的主要任务就是将需

求规格说明文档转换为软件设计文档,将需求阶段提出的问题,一一解释,形成详细设计文档,并根据功能要求,

定制相应数据结构、各种流程图等,为下一步编码做准备。 

(11)B) 【解析】每一个C语言的文件或函数都可以单独编译,但只有main函数的才可以执行。

 

(12)A) 【解析】预定义标识符是C语言中的标识符,在C语言中也有特定的含义,如函数printf、

scanf、sin等和编译预处理命令名(如define和include)。预定义标识符可以作为用户标识符使用,只是这样会

失去系统规定的原义。  

(13)B) 【解析】0xab是十六进制表示的常量。 

(14)A) 【解析】C语言用函数实现软件的模块化设计。  

(15)C) 【解析】C语言中,常常用一个标识符来代表一个常量,称为符号常量。符号常量在使用之

前要先定义,定义格式如下: 

    #define<符号常量名>(常量) 

    其中,<符号常量名)用标识符,习惯上用大写字母,<常量>可以是数字常量,也可以是字符 

(16)C) 【解析】题目中用scanf函数以整数的形式输入a,b的值。选项C)整型数字3后面有一个

空格,当输入空格时,scanf函数输入就会终止。  

(17)C) 【解析】C语言中char类型数据占字节数为1. 

(18)B) 【解析】由于3!=4的结果为1,而1>2的结果为假。 

(19)D) 【解析】使用switch语句直接处理多个分支,其一般形式为:  

switch(表达式) 

2012年9月笔试真卷及答案详解 第10页(共12页) 

{  

      case 常量表达式1: 

         语句1; 

      break; 

      

      case 常量表达式2: 

         语句2; 

      break;  

 

¼¼ 

      case 常量表达式n: 

         语句n; 

      break;  

 

      default: 

         语句n+1; 

      break; 

switch语句的执行流程是:首先计算switch后面圆括号中表达式的值,然后用此值依次与各个case的常量表

达式比较,若圆括号中表达式的值与某个case后面的常量表达式的值相等,就执行此case后面的语句,执行后

遇break语句就退出switch语句;若圆括号中表达式的值与所有case后面的常量表达式都不等,则执行default

后面的语句n+1,然后退出switch语句。 

(20)D) 【解析】由于a的初始值等于-2,所以while循环语言执行两次结束,此时变量a的值等于

1,变量b的等于2。 

(21)C) 【解析】定义指针变量时,必须将指针变量初始化为NULL(为空),否则,如果不赋给它

地址,系统会随机给它分配一个地址。 

(22)D) 【解析】两个连续的双引号:"",是一个字符串常量,称为“空串”。 

(23)D) 【解析】由于a的值为'H',符合(a>='A'&&a<='Z'),所以条件表达式的值等于(a-'A'+'a'),即

'h'。  

(24)B) 【解析】在函数main()中,第一次执行for循环时,b的值等于1,此时输出字母B;第二次

执行for循环时,b的值等于3,此时输出字母D;第三次执行for循环时,b的值等于8,此时输出字母I。 

(25)D) 【解析】x[0]可看作是由3个整型元素组成的一维数组,不可以用语句x[0]=0,为数组所有

元素赋初值0。 

(26)C) 【解析】给指针变量p赋NULL值,NULL是在stdio.h头文件中定义的预定义符,其代码

值为0,当执行p=NULL;语句后,称p为空指针。因为NULL的代码值为0,所以p=NULL;语句等价于p='\0';或

p=0;。 

(27)A) 【解析】因为指针变量p的初始值指向数组a,所以执行for循环语句后,数组a中的元素

的值不变。 

(28)B) 【解析】函数fun()的作用是求出二维数组a[][N]中每一行中的最大元素,所以在main()函数

中执行完fun(x,y)后,数组y中的元素为二维数组x[N][N]每一行的最大元素。 

(29)C) 【解析】程序执行后strcpy(a+1,b+2)后,字符数组a的值为“a2”,再进行字符串的连接

strcat(a,c+1),此时字符数组a的值为“a2yz”。 

(30)A) 【解析】选项A)是定义了字符数组str3[],并对其赋初值。  

(31)C) 【解析】这个程序的执行过程如下:当k=0时,s[1]=2!= '\0',k++=1,a=0+(s[1]- '\0')=2;当

k=1时,s[2]=1!= '\0',k++=2,a=2+(s[2]- '\0'+1)=2+(1+1)=4;当k=2时,s[3]=3!= '\0',k++=3,a=4+(s[3]- '\0')=4+3=7;

2012年9月笔试真卷及答案详解 第11页(共12页) 

当k=3时,s[4]=4!= '\0',k++=4,a=7+(s[4]- '\0'+1)=7+(4+1)=12;当k=4时,s[5]= '\0'结束循环,输出变量k和

a值。 

(32)A) 【解析】这个程序的执行过程是当i=0时,j=1,a[0][0]=oj=2,a[1][0]=t =a[2][0]=t;不置换;当i=2时,j=3,a[2][0]=t>a[3][0]=f;置换a[2][0]=f, a[3][0]=t;此时,a[2][0]=f,a[1][0]=t,

再置换a[2][0]=t,a[1][0]=f,;当i=3时,j=4,a[3][0]=f=a43][0]=f;不置换;所以a[1]的结果为fwo。  

(33)B) 【解析】函数fun1()的作用是输出局部变量a和b的值,在主函数中执行fun1(5,6)的结果是

输出5,6;函数fun2()的作用是给变量a和b分别赋值3,4;执行fun2()的作用是输出3,4。 

(34)A) 【解析】在函数func(int n)中定义了局部静态变量num,,其初始值等于1,所以在主函数中

执行func(3),输出4,此时静态变量num的值等于4,当退出函数func(3)时,其值不会丢失,所以当在执行func(4)

时,输出8。  

(35)C) 【解析】执行fun(&a,&b,q);语句时,在内存中开辟了一块内存空间,存放变量a与b的和,

并用指针变量q引用它,但是当这条语句执行结束,这块内存空间又释放了,指针这量q仍然引用的是变量a

的地址,所以输出结果为1。 

(36)D) 【解析】在主函数中,定义了结构体STU数组c[2],并对其赋初始值。执行f(c)时,在函数

f()中,把结构体变量b的值赋给了c[1]。 

(37)B) 【解析】typedef语句的作用仅仅是用“标识符”来代表已存在的“类型名”,并未产生新的

数据类型,原来类型名依然有效。为了便于识别,一般习惯将新的类型名用大写字母表示。 

(38)A) 【解析】函数的返回值类型可以是结构体类型。 

(39)B) 【解析】变量b的值等于2,其向左移动2位,其值等于8,即b<<2的值等于8。而3||b做

或运算的结果等于1。所以表达式(b<<2)/(3||b)的值等于8。 

(40)D) 【解析】在程序中定义了一个整型数组a[6],并对它赋初值,并以写入的方式打开了文件

d2.dat。然后利用一个for循环把数组a中的元素数据写入文件d2.dat中,调用函数rewind把将文件内部的位置

指针重新指向一个文件的开头,再利用for循环语句把文件中的数据依次写入到倒序排列的数组a中,最后输出

数组a中的数组元素。 

二、填空题 

(1)【1】6 

【解析】根据二叉树的性质,度为0的结点个数比度为2的结点多一个。所以本题中度为0的结点的个数

为24。在二叉树的第k层上,最多有2

k-1

(k>=1)个结点。所以第一层上最多1个结点,第二层上最多2个结点,

第三层上最多4个结点,第四层上最多8个结点,第5层上最多16个结点。前5层的总共结点个数等于31,而

本题度为2的结点个数为23,因此第5层上只能有8个度为2的结点,即在第6层上还有16个度为0的结点。 

(2)【2】20 

【解析】栈是先进后出的数据结构,所以当栈顶指针top等于20时,当前栈中的元素个数等于20。 

(3)【3】逻辑性 

【解析】数据性是指当总体逻辑结构改变时,其局部逻辑结构不变,从而根据局部逻辑结构编写的应

用程序不必修改。 

(4)【4】选择  

【解析】关系数据库中能实现的专门关系运算包括:选择、连接和投影。  

(5)【5】系统 

【解析】Unix操作系统属于系统软件。 

(6)【6】(a<=b)||(a>b)  

2012年9月笔试真卷及答案详解 第12页(共12页) 

【解析】表达式!(a<=b)含义是对a小于等于b取非,所以与其等价的表达式是(a<=b)||(a>b)。 

(7)【7】%lf%f  

【解析】对于变量a和b的输入采用实数的形式,所以scanf函数的输入格式符为 %lf%f。 

(8)【8】224  

【解析】当从键盘上输入01234567!时,根据程序中switch()语句,当输入的字符为'1'、'3'时,变量n1++;

所以n1的值等于2;当输入的字符为'2'、'4'时,变量n2++;所以n2的值等于2;当输入的字符为其他字符时,

变量n3++;所以n3的值等于4。所以答案为224。 

(9)【9】16  

【解析】程序的功能是求1、3、5、7之和,等于16。 

(10)【10】4321  

【解析】在程序的while循环中,每次求出n的个位上的数字,然后n的值减小10位,所以输出结果为4321。

 

(11)【11】7  

【解析】函数*st()的作用是返回*a与*c中较大数的指针,所以在主函数中,执行st(p)时,返回变量k的指

针,因而输出结果为7。 

(12)【12】22 

【解析】根据C语言中对带参数的宏的定义,2*(N+M)2))=2*(3+(3+1)*2)=22。 

(13)【13】2  

【解析】在C语言中在每个字符串的最后都增加一个字符串结束标识字符'\0',所以本题中的字符串在内存

中占有2个字节。 

(14)【14】6 

【解析】根据函数的迭代,f(3)=3*f(2)=3*2*f(1)=3*2*1*f(1)=3*2*1*1=6。 

(15)【15】 p->next  

【解析】在while循环中输出循环链表的每个结点,p->next指向当前结点的下一个结点。 

文档

2012年9月计算机二级C语言真题及答案

2012年9月笔试真卷及答案详解第1页(共12页)2012年9月全国计算机等级考试二级笔试试卷C语言程序设计(考试时间90分钟,满分100分)一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分)下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。(1)下列链表中,其逻辑结构属于非线性结构的是A)双向链表B)带链的栈C)二叉链表D)循环链表(2)设循环队列的存储空间为Q(1:35),初始
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top