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

更新时间:2024-03-26 23:30:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

校园网(www.xiaoyuan.com)

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

C语言程序设计

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

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

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

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

A)算法就是程序

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

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

A)各数据结点的存储空间可以不连续,但它们的存储顺序与逻辑顺序必须一致 B)各数据结点的存储顺序与逻辑顺序可以不一致,但它们的存储空间必须连续 C)进行插入与删除时,不需要移动表中的元素 D)以上三种说法都不对

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

A)叶子结点总是比度为2的结点少一个 B)叶子结点总是比度为2的结点多一个 C)叶子结点数是度为2的结点数的两倍

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

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

件的是( )。

A)学生成绩管理系统 B)C语言编译程序 C)UNIX操作系统 D)数据库管理系统

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

该系统总体结构图的深度是( )。 A)7 B)6

C)3

D)2

校园网(www.xiaoyuan.com)

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

A)设计测试用例 B)验证程序的正确性 C)发现程序中的错误 D)诊断和改正程序中的错误

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

A)在需求分析阶段建立数据字典 B)在概念设计阶段建立数据字典 C)在逻辑设计阶段建立数据字典 D)在物理设计阶段建立数据字

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

A)概念模式 B)内模式 C)外模式 D)数据模式

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

则由关系R和s得到关系T的操作是( )。 A)自然连接 B)差 C)交

D)并

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

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

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

A)C语言编写的函数源程序,其文件名后缀可以是C B)C语言编写的函数都可以作为一个独立的源程序文件 C)C语言编写的每个函数都可以进行独立的编译并执行 D)一个C语言程序只能有一个主函数

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

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

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

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

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

A)所谓常量,是指在程序运行过程中,其值不能被改变的量 B)常量分为整型常量、实型常量、字符常量和字符串常量 C)常量可分为数值型常量和非数值型常量 D)经常被使用的变量可以定义成常量

(14)若有定义语句:int a=10;double b=3.14;,则表达式'A'+a+b值的类型是( )。

A)char B)int C)double D)float

(15)若有定义语句:int x=12,3=8,z;,在其后执行语句z=0.9+x/y;,则Z的值为( )。

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

校园网(www.xiaoyuan.com)

(16)若有定义:int a,b;,通过语句scanf(\,&b);,能把整数3赋给变量a,

5赋给变量b的输入数据是( )。 A)3 5 B)3,5 C)3;5 D)35

(17)若有定义语句:intk1=10,k2=20;,执行表达式(k1=k1>k2)&&(k2=k2>k1)后,

k1和k2的值分别为( )。 A)0和1 B)0和20 C)10和1 D)10和20

(18)有以下程序

#include main()

{ int a=1,b=0; if(-a) b++;

else if(a=0)b+=2: else b+=3:

printf(\,b); }

程序运行后的输出结果是( )。 A)0 B)1 C)2 D)3

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

A)if(a)printf(\; else printf(\; B)if(a—0)printf(\;else printf(\; C)if(a!=0)p由tf(\;else printf(\; D)if(a=0)printf(\;else printf(\;

(20)有以下程序

#include main()

{ int a=7; while(a--);

printf(\; )

程序运行后的输出结果是( )。 A)-1 B)0 C)1 D)7

(21)以下不能输出字符A的语句是(注:字符A的ASCIl码值为65,字符a的ASCIl码

值为97)

A)printf(\; B)printf(\; C)printf(\; D)print-f(\;

(22)有以下程序(注:字符a的ASCIl码值为97)

#include main()

{ char*s={\;

校园网(www.xiaoyuan.com)

do

{ printf(”%d”,+s);++s;} while(+s); }

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

C)7890 D)979899

(23)若有定义语句:double a,+p=&a;以下叙述中错误的是( )。

A)定义语句中的*号是一个间址运算符 B)定义语句中的*号只是一个说明符

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

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

(24)有以下程序

#include

double f(double x); main()

{ doublea_0;inti;

for(i=0;i<30;i+=10) a+--f((double)i); printf(\; }

double f(double x) { return x*x+1; }

程序运行后的输出结果是( )。 A)503 B)401 C)500 D)1404

(25)若有定义语句:int year=2009,*p=&year;,以下不能使变量year中的值增至2010的

语句是( )。 A)*p+=1; B)(*p)++; C)++(*p); D)*p++;

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

A)int num[]={1,2,3,4,5,6}; B)int num[][3]={{1,2},3,4,5,6}; C)int num[2][4]=({1,2,{3,4},{5,6}}; D)int num[][4]={1,2,3,4,5,6};

(27)有以下程序

#include

void fun(int+p)

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

{ int a[10]={1,2,3,4,5,6,7,8,9,10}; fun(&a[3]); }

程序运行后的输出结果是( )。 A)5 B)6 C)8 D)9

校园网(www.xiaoyuan.com)

(28)有以下程序

#include

#define N 4

void fun(int a[][N],im b[]) { int i;

for(i=0;i

void main()

{ int x[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

程序运行后的输出结果是( )。 A)-12,-3,0,0, B)-3,-1,1,3, C)0,1,2,3, D)-3,-3,-3,-3

(29)有以下函数

int fun(char *x,char *y) { int n=0;

while((*x=*y)&&*x!='\\0'){ x++;y++;n++;} return n: )

函数的功能是( )。

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

B)统计x和y所指字符串中最前面连续相同的字符个数 C)将y所指字符串赋给X所指存储空间 D)统计x和y所指字符串中相同的字符个数

(30)若有定义语句:char *s1=\,*s2=\;,以下选项中,能够输出\的语句是(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 ┇ main()

{ double a[15],k; k=fun(a); ┇

}

则以下选项中错误的fun函数首部是( )。 A)double fun(double a[15]) B)double fun(double *a) C)double fun(double a[]) D)double fun(double a)

(32)有以下程序

#include #include

。 )

校园网(www.xiaoyuan.com)

main()

{ char a[5][10]={\}; int i,j;chart[10]; for(i=0;i<4;i++) for(j=i+1;j<5;j++)

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

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

程序运行后的输出结果是( )。 A)Beijing B)china C)welcome 33)有以下程序

#include int f(int m)

{ static int n=0; n+=m: return n; }

main()

{ int n=0;

printf(\; printf(\; )

程序运行后的输出结果是( )。 A)1,2 B)1,1 C)2,3 34)有以下程序

#include main()

{ char ch [3][5]={\); printf(\; }

程序运行后的输出结果是( )。 A)AAAA B)CC C)BBBCC 35)有以下程序

#include #include

void fun(char *w,int m) { char s,*p1,*p2;

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

while(p1

main()

{ char a[]=\;

D)tiananmen D)3,3

D)BBB

(校园网(www.xiaoyuan.com)

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

程序运行后的输出结果是( ) A)654321 B)116611 C)161616

D)123456

(36)有以下程序

#include #include

typedefstruct{char name[9];char sex;int score[2];}STU; STUf(STU a)

{ STU b={\; in ti:

strcpy(a.name,b.name); a.sex=b.sex;

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

main()

f STU c={\; d=f(c);

printf(\; printf(\; }

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

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

(37)有以下程序

#include main()

{ struct node{int n;stmct node+next;} *p;

structnodex[31]={(2,x+l},{4,x+2},{6,NULL}}; p=x;

printff(\;

printf(\; }

程序运行后的输出结果是( )。 A)2,3 B)2,4 C)3,4 D)4,6

(38)有以下程序

#include main()

{ int a=2,b;

b=a<<2; printr(\; }

校园网(www.xiaoyuan.com)

程序运行后的输出结果是( )。 A)2 B)4 C)6

D)8

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

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

B)在C程序的同一函数中,各复合语句内可以定义变量,其作用域仅限本复合语句内 C)C程序函数中定义的自动变量,系统不自动赋确定的初值 D)C程序函数的形参不可以说明为static型变量

(40)有以下程序

#include main()

{ FILE *fp,

int k,n,j,a[6]=<1,2,3,4,5,6}; fp=fopen(\;

for(i=0;i<6;i++) fprintf(fp,\; fclose(fp);

fp=fopen(\;

for(i=0;i<3;i++) fscanf(fp,\; fc|ose(fp);

printf(\; )

程序运行后的输出结果是( )。 A)1,2 B)3,4 C)5,6 D)123.456

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

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

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

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

元素。

(3)常见的软件开发方法有结构化方法和面向对象方法。对某应用系统经过需求分析建立数

据流图(DFD),则应采用 【3】 方法。

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

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

常被转换为 【5】 。

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

****a=10.b=20****

校园网(www.xiaoyuan.com)

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

#include main()

{ int a=37;

a%=9;printf(\; }

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

#include main() { int i,j;

for(i=6;i>3;i--)j=i; printf(”%d%d\\n”,i,j); }

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

#include main()

{ int i,n[]={0,0,0,0,0}; for(i=1;i<=2;i++) { n[i]=n[i-1]*3+1; printf(\; }

printf(\; }

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

#include main() { chara;

for(a=0;a<15;a+=5) { putchar(a+'A'); } printf(\; }

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

#include void fun(int x)

{ if(x/5>0) fun(x/5); prinff(\; }

main()

{ fun(11);printf(\

(12)有以下程序

#include

校园网(www.xiaoyuan.com)

main()

{ int c[3]={0},k,i; while((k=getchar())!='\\n') c[k-'A']++;

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

若程序运行时从键盘输入ABcAcC<回车>,则输出结果为 【12】 。

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

#include main()

{ int n[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(\; }

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

存放a数组中数据的个数。请填空。 #include

void fun(int s[],int *n,int k,int x) { int i;

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

*n=*n+ 【15】 ; }

main()

{ int a[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

校园网(www.xiaoyuan.com)

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) 【解析】常量指在程序运行过程中,其值不能被改变的量。常量分为整型常量:

校园网(www.xiaoyuan.com)

也就是整常数,实型常量,字符型常量和字符串常量。常量也可以按数据类型分为为数据常量和非数据常量。变量是指在程序运行过程中,其值能被改变的量。

(14)C) 【解析】在c语言中不同类型的数据进行运算时,除了强制数据类型转换外,都要进行默认的数据类型转换,通常转换为精度较高的数据类型。对于本题来说,字符型数据'A'与整型a相加转换为整型数据,其和再与双精度型数据b相加,要转换为双精度型数据。 (15)B) 【解析】由于x,y,z都是整型数据,所以x除以Y的值为整型数值1,1和0.9相加得到1.9,再转换为整型数1赋给整型变量2。

(16)C) 【解析】在采用scanf这个函数输人数据时,要严格遵守其输入的规则定义。本题此函数定义的规则是,在两个整数之间加分号输入。

(17)B) 【解析】由于k1等于10,k2等于20,所以关系表达式k1>k2的值为假,即等于0,所以在执行逻辑表达式(k1=k1>k2)&&(k2=k=2>k1)的第一个赋值表达式k1=k1>k2执行后,k1的值等于0。又因为在逻辑与表达式中只要第表达式的值为假时,整个逻辑表达式的值就为假,第二表达式不执行,k2值不改变。

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

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

(20)A) 【解析】在while语句中,先判断while后面的表达式是否为0,如果为0,则退出循环,否则的执行循环。在本题中,当变量a的值经过几次循环后,其值等于0时,退出while循环语句,变量a再执行自减运算,所以其值等于-1。

(21)B) 【解析】在选项B)的输出函数中,大写字符'A'以整型数据的形式输出。 (22)B) 【解析】因为小写字符a,b,c的ASCII的值分别为97,98,99,而在d0 while循环语句中,每次对字符的ASCII的值取余数并输出,第一次循环输出7,第二次循环输出8,第三次循环输出9。

(23)A) 【解析】在指针定义语句double a,*p=&a中,指针变量p前面的*号,只是一个说明说明变量p是指针类型的变量。

(24)A 【解析】由r函数f的作用是对形参x求平方再加1,所以在主函数中,循环第一次执行后变量a的值等于1,第二次执行后,变量a的值等于102,第三次执行后,变量a的值等于503。

(25)D) 【解析】由于自加运算符++的运算级高于间接运算*的运算级,所以选项D)的表达式*p++不能使变量year中的值增至2010。

(26)C) 【解析】在选项C)的数组定义中,赋值号左边定义了一个2行4列的二二维数组,而在右边定义了一个3行2列的二维数组。

(27)D) 【解析】函数fun的功能是输出数组P的第5个元素,在主函数中,把元素a[3]的地址赋给函数fun,因为在c语言中,数组的下标是从0开始,所以输出数组a中的第8个元素,即9。

校园网(www.xiaoyuan.com)

(28)B) 【解析】fun函数的功能是求出一二维数组a中第i行第i个元素与第N-1-i元素的差,赋给b[i]。在主函数中,把实参二维数组x和一维数组Y传递给形参a和b,最后输出一维数组Y中元素的值。

(29)B) 【解析】在while循环中的判断表达式为(*x=*y)&&*x!='\\0',所以只要字符串x与y的当前字符不相等时,循环就结束。

(30)D) 【解析】字符串比较函数strcmp的功能是对s1和s2所指字符串进行此较。如果s1s2,返刚正数,所以对于本题来说,能够输出“OK”的语句是D)选项所指的语句。 (31)D) 【解析】由函数fun在主函数中的调用形式可以看出,函数fun()的函数返回值类型为double,形参为一维数组或指针变量。

(32)C) 【解析】由程序中的两层for循环可知,对数组串数组进行从小到大的排序,所以字符串数组a[][],经过排序后值应该为(\,\,\,\,\you\,输出字符串a[3]的值为“welcome”。

(33)A) 【解析】由于在函数f中,变量n为静态局部变量,所以在主函数中第一次调用函数f后,变量n的值等于1,当第二调用函数f时,在函数f的内部静态局部变量n的值仍然保留等于1,所以返回函数值等于2。

(34)D) 【解析】宇符串数组ch的元素下标是从0开始的,所以数组元素ch[1]值为字符串“BBB”。

(35)A) 【解析】函数fun的功能是将字符串W中的元素从大到小进行排列,所以在主函数中调用函数fun后,字符串a的元素从大到小进行了排列。

(36)A) 【解析】在C语言中,函数实参与形参之间数据的传递是传值,也就是说在用实参调用形参时,是把实参的值拷贝一份给形参,丽实参的值并不变化,仍是原来的值。所以对于本题来说,在主函数中调f(e)后,实参e的值并不会变化,仍是原值。在函数f中把局部变量b的值依次返回给变量d。

(37)B) 【解析】在程序中由结构体node的数组x[3]组成了一个线性链表,指针p指向链表的第一结点x[0],所以首先输出2,p->nex指向第二个结点x[1],所以输出4。

(38)D) 【解析】表达式a<<2,把a向左移动2位,相当于扩大4倍。

(39)A) 【解析】在函数定义的静态变量,只需要赋值1次,即可保存初始值,不需要每次调用时都赋初始值。

(40)C) 【解析】在程序中首先把数组a中的各个元素写入到文件d2.dm中,然后利用循环语句每次从d2.dat中读出两个元素赋给变量k,n;循环共执行3次,所以最后变量k,n的值等于5,6。

本文来源:https://www.bwwdw.com/article/tn9r.html

Top