2011年9月笔试真卷及答案详解第1页(共12页)
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)7B)6C)3D)2
(6)程序调试的任务是()。
A)设计测试用例B)验证程序的正确性
C)发现程序中的错误D)诊断和改正程序中的错误
(7)下列关于数据库设计的叙述中,正确的是()。
A)在需求分析阶段建立数据字典B)在概念设计阶段建立数据字典
C)在逻辑设计阶段建立数据字典D)在物理设计阶段建立数据字典
(8)数据库系统的三级模式不包括()。
A)概念模式B)内模式C)外模式D)数据模式
XY系统
功能1功能2功能3
功能2.1功能2.2功能2.3
2011年9月笔试真卷及答案详解第2页(共12页)
(9)有三个关系R、S利T如下:
RST
ABCABCABC
a12A12c31
b21b21
c31
则由关系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)若有定义语句:inta=10;doubleb=3.14;,则表达式''A''+a+b值的类型是()。
A)charB)intC)doubleD)float
(15)若有定义语句:intx=12,y=8,z;,在其后执行语句z=0.9+x/y;,则z的值为()。
A)l.9B)1C)2D)2.4
(16)若有定义:inta,b;,通过语句scanf("%d;%d",&a,&b);,能把整数3赋给变量a,5赋给变
量b的输入数据是()。
A)35B)3,5C)3;5D)35
(17)若有定义语句:intkl=10,k2=20;,执行表达式(kl=kl>k2)&&(k2=k2>k1)后,kl和k2的值
分别为()。
A)0和1B)0和20C)10和1D)10和20
(18)有以下程序
#include
main()
{inta=1,b=0;
if(--a)b++;
elseif(a==0)b+=2;
elseb+=3;
printf("%d\n",b);
}
2011年9月笔试真卷及答案详解第3页(共12页)
程序运行后的输出结果是()。
A)0B)1C)2D)3
(19)下列条件语句中,输出结果与其他语句不同的是()。
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
main()
{inta=7;
while(a--);
printf("%d\n",a);
}
程序运行后的输出结果是()。
A)-1B)0C)lD)7
(21)以下不能输出字符A的语句是(注:字符A的ASCII码值为65,字符a的ASCII码值为
97)
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
main()
{chars={"abc"};
do
{printf("%d",s%10);++s;}
while(s);
}
程序运行后的输出结果是()。
A)abcB)789C)7890D)979899
(23)若有定义语句:doublea,p=&a;以下叙述中错误的是()。
A)定义语句中的号是一个间址运算符
B)定义语句中的号只是一个说明符
C)定义语句中的p只能存放double类型变量的地址
D)定义语句中,p=&a把变量a的地址作为初值赋给指针变量p
(24)有以下程序
#include
doublef(doublex);
main()
{doublea=0;inti;
for(i=0;i<30;i+=10)a+=f((double)i);
printf("%5.0f\n",a);
}
doublef(doublex)
{returnxx+1;}
程序运行后的输出结果是()。
2011年9月笔试真卷及答案详解第4页(共12页)
A)503B)401C)500D)1404
(25)若有定义语句:intyear=2009,p=&year;,以下不能使变量year中的值增至2010的语句
是()。
A)p+=l;B)(p)++;C)++(p);D)p++;
(26)以下定义数组的语句中错误的是()。
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
voidfun(intp)
{printf("%d\n",p[5]);}
main()
{inta[10]={1,2,3,4,5,6,7,8,9,10};
fun(&a[3]);
}
程序运行后的输出结果是()。
A)5B)6C)8D)9
(28)有以下程序
#include
#defineN4
voidfun(inta[][N],intb[])
{inti;
for(i=0;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 }
程序运行后的输出结果是()。
A)-12,-3,0,0,B)-3,-1,1,3,C)0,1,2,3,D)-3,-3,-3,-3,
(29)有以下函数
intfun(charx,chary)
{intn=0;
while((x==y)&&x!=''\0''){x++;y++;n++;}
returnn;
}
函数的功能是()。
A)查找x和y所指字符串中是否有''\0''
B)统计x和y所指字符串中最前面连续相同的字符个数
C)将y所指字符串赋给x所指存储空间
D)统计x和y所指字符串中相同的字符个数
(30)若有定义语句:chars1="OK",s2="ok";,以下选项中,能够输出"OK"的语句是()。
A)if(strcmp(sl,s2)==0)puts(sl);B)if(strcmp(s1,s2)!=0)puts(s2);
C)if(strcmp(s1,s2)==1)puts(sl,);D)if(strcmp(sl,s2)!=0)puts(s1);
(31)以下程序的主函数中调用了在其前面定义的fun函数
2011年9月笔试真卷及答案详解第5页(共12页)
#include
┆
main()
{doublea[15],k;
k=fun(a);
┆
}
则以下选项中错误的fun函数首部是()。
A)doublefun(doublea[15])B)doublefun(doublea)
C)doublefun(doublea[])D)doublefun(doublea)
(32)有以下程序
#include
#include
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]);
}
程序运行后的输出结果是()。
A)BeijingB)chinaC)welcomeD)tiananmen
(33)有以下程序
#include
intf(intm)
{staticintn=0;
n+=m;
returnn;
}
main()
{intn=0;
printf("%d,",f(++n));
printf("%d\n",f(n++));
}
程序运行后的输出结果是()。
A)1,2B)1,1C)2,3D)3,3
(34)有以下程序
#include
main()
{charch[3][5]={"AAAA","BBB","CC"};
printf("%s\n",ch[1]);
}
程序运行后的输出结果是()。
A)AAAAB)CCC)BBBCCD)BBB
(35)有以下程序
#include
2011年9月笔试真卷及答案详解第6页(共12页)
#include
voidfun(charw,intm)
{chars,p1,p2;
p1=w;p2=w+m-1;
while(p1 }
main()
{chara[]="123456";
fun(a,strlen(a));puts(a);
}
程序运行后的输出结果是()。
A)654321B)116611C)161616D)123456
(36)有以下程序
#include
#include
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={"Qiam",''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)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
main()
{structnode{intn;structnodenext;}p;
structnodex[3]={{2,x+1},{4,x+2},{6,NULL}};
p=x;
printf("%d,",p->n);
printf("%d\n",p->next->n);
}
程序运行后的输出结果是()。
A)2,3B)2,4C)3,4D)4,6
(38)有以下程序
#include
main()
{inta=2,b;
b=a<<2;printf("%d\n",b);
2011年9月笔试真卷及答案详解第7页(共12页)
}
程序运行后的输出结果是()。
A)2B)4C)6D)8
(39)以下选项中叙述错误的是()。
A)C程序函数中定义的赋有初值的静态变量,每调用一次函数,赋一次初值
B)在C程序的同一函数中,各复合语句内可以定义变量,其作用域仅限本复合语句内
C)C程序函数中定义的自动变量,系统不自动赋确定的初值
D)C程序函数的形参不可以说明为static型变量
(40)有以下程序
#include
main()
{FILEfp;
intk,n,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]);
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);
}
程序运行后的输出结果是()。
A)l,2B)3,4C)5,6D)123,456
二、填空题(每空2分,共30分)
请将每空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。
(1)数据结构分为线性结构与非线性结构,带链的栈属于【1】。
(2)在长度为n的顺序存储的线性表中插入一个元素,最坏情况下需要移动表中【2】个元
素。
(3)常见的软件开发方法有结构化方法和面向对象方法。对某应用系统经过需求分析建立数据流
图(DFD),则应采用【3】方法。
(4)数据库系统的核心是【4】。
(5)在进行关系数据库的逻辑设计时,E-R图中的属性常被转换为关系中的属性,联系通常被转
换为【5】。
(6)若程序中已给整型变量a和b赋值l0和20,请写出按以下格式输出a、b值的语句【6】。
a=10,b=20
(7)以下程序运行后的输出结果是【7】。
#include
main()
{inta=37;
a%=9;printf("%d\n",a);
}
(8)以下程序运行后的输出结果是【8】。
#include
2011年9月笔试真卷及答案详解第8页(共12页)
main()
{inti,j;
for(i=6;i>3;i--)j=i;
printf("%d%d\n",i,j);
}
(9)以下程序运行后的输出结果是【9】。
#include
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)以下程序运行后的输出结果是【10】。
#include
main()
{chara;
for(a=0;a<15;a+=5)
{putchar(a+''A'');}
printf("\n");
}
(11)以下程序运行后的输出结果是【11】。
#include
voidfun(intx)
{if(x/5>0)fun(x/5);
printf("%d",x);
}
main()
{fun(11);printf("\n");}
(12)有以下程序
#include
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<回车>,则输出结果为【12】。
(13)以下程序运行后的输出结果是【13】。
#include
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存放
2011年9月笔试真卷及答案详解第9页(共12页)
a数组中数据的个数。请填空。
#include
voidfun(ints[],intn,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 }
|
|