历年二级C语言笔试真题及详细答案.docx

上传人:b****7 文档编号:11228644 上传时间:2023-02-25 格式:DOCX 页数:394 大小:335.91KB
下载 相关 举报
历年二级C语言笔试真题及详细答案.docx_第1页
第1页 / 共394页
历年二级C语言笔试真题及详细答案.docx_第2页
第2页 / 共394页
历年二级C语言笔试真题及详细答案.docx_第3页
第3页 / 共394页
历年二级C语言笔试真题及详细答案.docx_第4页
第4页 / 共394页
历年二级C语言笔试真题及详细答案.docx_第5页
第5页 / 共394页
点击查看更多>>
下载资源
资源描述

历年二级C语言笔试真题及详细答案.docx

《历年二级C语言笔试真题及详细答案.docx》由会员分享,可在线阅读,更多相关《历年二级C语言笔试真题及详细答案.docx(394页珍藏版)》请在冰豆网上搜索。

历年二级C语言笔试真题及详细答案.docx

历年二级C语言笔试真题及详细答案

2011年9月全国计算机等级考试二级笔试试卷C语言程序设计

一、选择题

下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。

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

A)算法就是程序B)设计算法时只需要考虑数据结构的设计C)设计算法时只需要考虑结果的可靠性D)以上三种说法都不对

(2)下列关于线性链表的叙述中,正确的是(C)。

A)各数据结点的存储空间可以不连续,但它们的存储顺序与逻辑顺序必须一致

B)各数据结点的存储顺序与逻辑顺序可以不一致,但它们的存储空间必须连续

C)进行插入与删除时,不需要移动表中的元素

D)以上三种说法都不对

(3)下列关于二叉树的叙述中,正确的是(B)。

A)叶子结点总是比度为2的结点少一个

B)叶子结点总是比度为2的结点多一个

C)叶子结点数是度为2的结点数的两倍

D)度为2的结点数是度为1的结点数的两倍

(4)软件按功能可以分为应用软件、系统软件和支撑软件(或工具软件)。

下面属于应用软件的是(A)。

A)学生成绩管理系统B)C语言编译程序

C)UNIX操作系统D)数据库管理系统

(5)某系统总体结构图如下图所示:

该系统总体结构图的深度是(C)。

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

(6)程序调试的任务是(D)。

A)设计测试用例B)验证程序的正确性

C)发现程序中的错误D)诊断和改正程序中的错误

(7)下列关于数据库设计的叙述中,正确的是(A)。

A)在需求分析阶段建立数据字典B)在概念设计阶段建立数据字典

C)在逻辑设计阶段建立数据字典D)在物理设计阶段建立数据字典

(8)数据库系统的三级模式不包括(D)。

A)概念模式B)内模式

C)外模式D)数据模式

(9)有三个关系R、S利T如下:

则由关系R和S得到关系T的操作是(B)。

A)自然连接B)差C)交D)并

(10)下列选项中属于面向对象设计方法主要特征的是(A)。

A)继承B)自顶向下C)模块化D)逐步求精

(11)以下叙述中错误的是(C)。

A)C语言编写的函数源程序,其文件名后缀可以是.C

B)C语言编写的函数都可以作为一个独立的源程序文件

C)C语言编写的每个函数都可以进行独立的编译并执行

D)一个C语言程序只能有一个主函数

(12)以下选项中关于程序模块化的叙述错误的是(C)。

A)把程序分成若干相对独立的模块,可便于编码和调试

B)把程序分成若干相对独立、功能单一的模块,可便于重复使用这些模块

C)可采用自底向上、逐步细化的设计方法把若干独立模块组装成所要求的程序

D)可采用自顶向下、逐步细化的设计方法把若干独立模块组装成所要求的程序

(13)以下选项中关于C语言常量的叙述错误的是(D)。

A)所谓常量,是指在程序运行过程中,其值不能被改变的量

B)常量分为整型常量、实型常量、字符常量和字符串常量

C)常量可分为数值型常量和非数值型常量

D)经常被使用的变量可以定义成常量

(14)若有定义语句:

inta=10;doubleb=3.14;,则表达式'A'+a+b值的类型是(C)。

A)charB)intC)doubleD)float

(15)若有定义语句:

intx=12,y=8,z;,在其后执行语句z=0.9+x/y;,则z的值为(B)。

A)1.9B)1C)2D)2.4

(16)若有定义:

inta,b;,通过语句scanf("%d;%d",&a,&b);,能把整数3赋给变量a,5赋给变量b的输入数据是(C)。

A)35B)3,5C)3;5D)35

(17)若有定义语句:

intk1=10,k2=20;,执行表达式(k1=k1>k2)&&(k2=k2>k1)后,k1和l(2的值分别为(B)。

A)0和1B)0和20C)10和1D)10和20

(18)有以下程序

#include<stdio.h>

main()

{inta=1,b=0;

if(--a)b++;

elseif(a==0)b+=2;

elseb+=3;

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

}

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

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

(19)下列条件语句中,输出结果与其他语句不同的是(D)。

A)if(a)printf("%d\-n",x);elseprintf("%d\n",y);

B)if(a==0)printf("%d\n",y);elseprintf("%d\n",x);

C)if(a!

=0)printf("%d\n",x);elseprintf("%d\n",y);

D)if(a==0)printf("%d\n",x);elseprintf("%d\n",y);

(20)有以下程序

#include<stdio.h>

main()

{inta=7;

while(a--);

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

}

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

A)-1B)0C)1D)7

(21)以下不能输出字符A的语句是(注:

字符A的ASCII码值为65,字符a的ASCII码值为97)(B)

A)printf(“%c\n",'a'-32);B)printf("%d\n",'A');

C)printf("%c\n",65);D)printf("%c\n",'B'-1);

(22)有以下程序(注:

字符a的ASCII码值为97)

#include<stdio.h>

main()

{char*s={"abc"};

do

{printf("%d","s%10);++s;)

while(*s);

}

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

A)abcB)789C)7890D)979899

(23)若有定义语句:

doublea,*p=&a;以下叙述中错误的是(A)。

A)定义语句中的+号是一个间址运算符

B)定义语句中的*号只是一个说明符

C)定义语句中的p只能存放double类型变量的地址

D)定义语句中,*p=&a把变量a的地址作为初值赋给指针变量p

(24)有以下程序

#include<stdio.h>

doublef(doublex);

main()

{doublea=0;inti;

for(i=0;i<30;i+=10)a+=f(double)i);

printf("%5.0f\n",a);

}

doublef(doublex)

{returnx*x+1;}

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

A)503B)401C)500D)1404

(25)若有定义语句:

intyear=2009,*p=&year;,以下不能使变量year中的值增至2010的语句是(D)。

A)*p+=1;B)(*p)++;C)++(*p);D)*p++;

(26)以下定义数组的语句中错误的是(C)。

A)intnum[]={1,2,3,4,5,6};B)intnum[][3]={{1,2},3,4,5,6);

C)intnum[2][4]=({1,2},{3,4},{5,6));D)intnum[][4]={1,2,3,4,5,6};

(27)有以下程序

#include<stdio.h>

voidfun(int*p)

{printf("%d\n",p[5]);}

main()

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

fun(&a[3]);

}

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

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

(28)有以下程序

#include<stdio.h>

#defineN4

voidfun(inta[][N],intb[])

{inti;

for(i=0;i<N;i++)b[i]=a[i][i]-a[i][N-1-i];

}

voidmain()

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

fun(x,y);

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

}

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

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

(29)有以下函数

intfun(char*x,char*y)

{intn=0;

while((*x==*y)&&*x!

='\0'){x++;y++;n++;}

returnn;

}

函数的功能是(B)。

A)查找x和y所指字符串中是否有'\0'

B)统计x和y所指字符串中最前面连续相同的字符个数

C)将y所指字符串赋给x所指存储空间

D)统计x和y所指字符串中相同的字符个数

(30)若有定义语句:

char*s1="OK",*s2="ok";,以下选项中,能够输出"OK"的语句是(D)。

A)if(strcmp(s1,s2)==0)puts(s1);B)if(strcmp(s1,s2)!

=0)puts(s2);

C)if(strcmp(s1,s2)==1)puts(s1,);D)if(strcmp(s1,s2)!

=0)puts(s1);

(31)以下程序的主函数中调用了在其前面定义的fun函数

#include<stdio.h>

main()

{doublea[15],k;

k=fun(a);

}

则以下选项中错误的fun函数受部是(D)。

A)doublefun(doublea[15])B)doublefun(double*a)

C)doublefun(doublea[])D)doublefun(doublea)

(32)有以下程序

#include<stdio.h>

#include<string.h>

main()

{chara[5][10]={"china","beijing","you","tiananmen","welcome");

inti,j;chart[10];

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

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

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

{strcpy(t,a[i]);strcpy(a[i],a[j]);strcpy(a[j],t);}

puts(a[3]);

}

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

A)BeijingB)chinaC)welcomeD)tiananmen

(33)有以下程序

#include<stdio.h>

intf(intm)

{staticintn=0;

n+=m;

returnn;

}

main()

{intn=0;

printf("%d,",f(++n));

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

}

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

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

(34)有以下程序

#include<stdio.h>

main()

{charch[3][5]={"AAAA","BBB","CC"};

printf("%s\n",ch[1]);

}

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

A)AAAAB)CCC)BBBCCD)BBB

(35)有以下程序

#include<stdio.h>

#include<string.h>

voidfun(char*w,intm)

{chars,*p1,*p2;

p1=w;p2=w+m-1;

while(p1<p2){s=*p1;*p1=*p2;*p2=s;p1++;p2--;}

}

main()

{chara[]="123456";

fun(a,strlen(a));puts(a);

}

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

A)654321B)116611C)161616D)123456

(36)有以下程序

#include<stdio.h>

#include<string.h>

typedefstruct{charname[9];charsex;intscore[2];}STU;

STUf(STUa)

{STUb={"Zhao",'m',85,90);

inti;

strcpy(a.name,b.name);

a.sex=b.sex;

for(i=0;i<2;i++)a.score[i]=b.score[i];

returna;

}

main()

{STUc={"Qian",'f',95,92),d;

d=f(c);

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

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

}

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

A)Zhao,m,85,90,Qian,f,95,92B)Zhao,m,85,90,Zhao,m,85,90

C)Qian,f,95,92,Qian,f,95,92D)Qian,f,95,92,Zhao,m,85,90

(37)有以下程序

#include<stdio.h>

main()

{structnode{intn;structnode*next;}*p;

structnodex[3]={{2,x+1},{4,x+2},{6,NULL}};

p=x;

printf("%d,",p->n);

printf("%d\n",p->next->n);

}

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

A)2,3B)2,4C)3,4D)4,6

(38)有以下程序

#include<stdio.h>

main()

{inta=2,b;

b=a<<2;pfinff("%d\n",b);

}

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

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

(39)以下选项中叙述错误的是(A)。

A)C程序函数中定义的赋有初值的静态变量,每调用一次函数,赋一次初值

B)在C程序的同一函数中,各复合语句内可以定义变量,其作用域仅限本复合语句内

C)C程序函数中定义的自动变量,系统不自动赋确定的初值

D)C程序函数的形参不可以说明为static型变量

(40)有以下程序

#include<stdio.h>

main()

{FILE*fp;

intk,n,i,a[6]={1,2,3,4,5,6};

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

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

fclose(fp);

fp=fopen("d2.dat","r");

for(i=0;i<3;i++)fscanf(fp,"%d%d",&k,&n);

fclose(fp);

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

}

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

A)1,2B)3,4C)5,6D)123,456

二、填空题

请将每空的正确答案写在横线上。

(1)数据结构分为线性结构与非线性结构,带链的栈属于______。

(2)在长度为n的顺序存储的线性表中插入一个元素,最坏情况下需要移动表中______个元素。

(3)常见的软件开发方法有结构化方法和面向对象方法。

对某应用系统经过需求分析建立数据流图(DFD),则应采用______方法。

(4)数据库系统的核心是______。

(5)在进行关系数据库的逻辑设计时,E-R图中的属性常被转换为关系中的属性,联系通常被转换为______。

(6)若程序中已给整型变量a和b赋值10和20,请写出按以下格式输出a、b值的语句______。

****a=10,b=20****

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

#include<stdio.h>

main()

{inta=37;

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

}

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

#include<stdio.h>

main()

{inti,j;

for(i=6;i>3;i--)j=i;

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

}

(9)以下程序运行后的输出结果是______。

#include<stdio.h>

main()

{inti,n[]={0,0,0,0,0);

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

{n[i]=n[i-1]*3+1;

printf("%d",n[i]);

}

printf("\n");

}

(10)以下程序运行后的输出结果是______。

#include<stdio.h>

main()

{chara;

for(a=0;a<15;a+=5)

{putchar(a+'A');}

printf("\n");

}

(11)以下程序运行后的输出结果是______。

#include<stdio.h>

voidfun(intx)

{if(x/5>0)fun(x/5);

printf("%d",x);

}

main()

{fun(11);pfintf("\n");}

(12)有以下程序

#include<stdio.h>

main()

{intc[3]={0},k,i;

while((k=getchar())!

='\n')

c[k-'A']++;

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

}

若程序运行时从键盘输入ABCACC<回车>,则输出结果为______。

(13)以下程序运行后的输出结果是______。

#include<stdio.h>

main()

{intn[2],i,j;

for(i=0;i<2;i++)n[i]=0;

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

for(j=0;j<2;j++)n[j]=n[i]+1;

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

}

(14)以下程序调用fun函数把x中的值插入到a数组下标为k的数组元素中。

主函数中,n存放a数组中数据的个数。

请填空。

#include<stdio.h>

voidfun(ints[],int*n,intk,intx)

{inti;

for(i=*n-1;i>=k;i--)s[(14)]=s[i];

s[k]=x;

*n=*n+(15);

}

main()

{inta[20]={1,2,3,4,5,6,7,8,9,10,11},i,x=0,k=6,n=11;

fun(a,&n,k,x);

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

}

2011年9月全国计算机等级考试二级C语言程序设计答案及详解

一、选择题

(1)D)[解析]所谓算法是指解题方案的准确而完整的描述。

是一组严谨地定义运算顺序的规则,并且每一个规则都是有效的,且是明确的,此顺序将在有限的次数下终止。

算法不等于程序,也不等于计算方法。

设计算法时不仅要考虑对数据对象的运算和操作,还要考虑算法的控制结构。

(2)C)[解析]线性表的链式存储结构称为线性链表。

在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致,而数据元素之间的逻辑关系是由指针域来确定的。

(3)B)[解析]由二叉树的性质可以知道在二叉树中叶子结点总是比度为2的结点多一个。

(4)A)[解析]学生成绩管理系统为应用软件。

(5)C)[解析]这个系统总体结构图是一棵树结构,在树结构中,根结点在第1层,同一层上所有子结点都在下一层,由系统总体结构图可知,这棵树共3层。

在树结构中,树的最大层次称为树的深度。

所以这棵树的深度为3。

(6)D)[解析]所谓程序调试,是将编制的程序投入实际运行前,用手工或编译程序等方法进行测试,修正语法错误和逻辑错误的过程。

其任务是诊断和改正程序中的错误。

(7)A)[解析]数据库设计目前一般采用生命周期法,即将整个数据库应用系统的开发分解成目标独立的若干阶段。

分别是:

需求分析阶段、概念设计阶段、逻辑设计阶段、物理设计阶段、编码阶段、测试阶段、运行阶段、进一步修改阶段。

数据字典是对系统中数据的详尽描述,是各类数据属性的清单。

对数据设计来讲,数据字典是进行详细的数据收集和数据分析所获得的主要结果。

(8)D)[解析]数据库系统的三级模式包括概念模式、外模式和内模式(物理模式)。

(9)B)[解析]由三个关系R、S和T的结构可以知道,关系T是由关系R、S经过差运算得到的。

(10)A)[解析]面向对象设计方法的主要特征有封装性、继承性和多态性。

而结构化程序设计方法的主要原则有自顶向下,逐步求精,模块化,限制使用goto语句。

(11)C)[解析]C语言程序是从main函数开始执行的,每一个函数可以进行独立的编译。

(12)C)[解析]如果应用结构化程序设计方法设计程序,那么可采用自顶向下,逐步细化的设计方法把若干独立模块组装成所要求的程序。

(13)D)[解析]常量指在程序运行过程中,其值不能被改变的量。

常量分为整型常量,也就是整常数,实型常量,字符型常量和字符串常量。

常量也可以按数据类型分为为数据常量和非数据常量。

变量是指在程序运行过程中,其值能被改变的量。

(14)C)[解析]在C语言中不同类型的数据进行运算时,除了强制数据类型转换外,都要进行默认的数据类型转换,通常转换为精度较高的数据类型。

对于本题来说,字符型数据'A'与整型a相加转换为整型数据,其和再与双精度型数据b相加,要转换为双精度型数据。

(15)B)[解析]由于x,y,z都是整型数据,所以x除以y的值为整型数值1,1和0.9相加得到1.9,再转换为整型数1赋给整型变量z。

(16)C)[解析]在采用scanf这个函数输入数据时,要严格遵守其输入的规则定义。

本题此函数定义的规则是,在两个整数之间加分号输入。

(17)B)[解析]由于k1等于10,k2等于20,所以关系表达式k1>k2的值为假,即等于0,所以在执行逻辑表达式(k1=k1>k2)&&(k2=k2>k1)的第一个赋值表达式k1=k1>k2执行后,k1的值等于0。

又因为在逻辑与表达式中只要第一表达式的值为假时,整个逻辑表达式的值就为假,第二表达式不执行,k2值不改变。

(18)C)[解析]由于变量a的初始值等于1,所以在程序中执行if(--a)后,a的值等于0,执行elseif(a==0)b+=2;这条语句后,变量b的值等于2。

(19)D)[解析]选项A)、B)、C)这三条语句都是在变量不等于0的情况下,输出x;等于0的情况下输出y,而选项D)则正好相反。

(20)A)[解析]在while语句中,先判断while后面的表达式是否为0,如果为0,则退出循环,否则执行循环体。

在本题中,当变量a的值

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

当前位置:首页 > 经管营销 > 经济市场

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

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