二级C语言真题.docx
- 文档编号:24917446
- 上传时间:2023-06-02
- 格式:DOCX
- 页数:22
- 大小:50.28KB
二级C语言真题.docx
《二级C语言真题.docx》由会员分享,可在线阅读,更多相关《二级C语言真题.docx(22页珍藏版)》请在冰豆网上搜索。
二级C语言真题
2011年9月全国计算机等级考试二级笔试试卷C语言程序设计
一、选择题
下列各题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)数据模式
(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)若有定义语句:
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)1.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)若有定义语句:
intk1=10,k2=20;,执行表达式(k1=k1>k2)&&(k2=k2>k1)后,k1和l(2的值分别为()。
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);
}
程序运行后的输出结果是()。
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<stdio.h>
main()
{inta=7;
while(a--);
pfintf("%d\n",a);
}
程序运行后的输出结果是()。
A)-1B)0C)1D)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<stdio.h>
main()
{char*s={"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<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)503B)401C)500D)1404
(25)若有定义语句:
intyear=2009,*p=&year;,以下不能使变量year中的值增至2010的语句是()。
A)*p+=1;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<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]);
}
程序运行后的输出结果是()。
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");
}
程序运行后的输出结果是()。
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;
}
函数的功能是()。
A)查找x和y所指字符串中是否有'\0'
B)统计x和y所指字符串中最前面连续相同的字符个数
C)将y所指字符串赋给x所指存储空间
D)统计x和y所指字符串中相同的字符个数
(30)若有定义语句:
char*s1="OK",*s2="ok";,以下选项中,能够输出"OK"的语句是()。
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函数受部是()。
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]);
}
程序运行后的输出结果是()。
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)1,2B)1,1C)2,3D)3,3
(34)有以下程序
#include<stdio.h>
main()
{charch[3][5]={"AAAA","BBB","CC"};
printf("%s\n",ch[1]);
}
程序运行后的输出结果是()。
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)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)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);
}
程序运行后的输出结果是()。
A)2,3B)2,4C)3,4D)4,6
(38)有以下程序
#include<stdio.h>
main()
{inta=2,b;
b=a<<2;pfinff("%d\n",b);
}
程序运行后的输出结果是()。
A)2B)4C)6D)8
(39)以下选项中叙述错误的是()。
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);
}
程序运行后的输出结果是()。
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的值经过几次循环后,其值等于0时,退出while循环语句,变量a再执行自减运算,所以其值等于-1。
(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 二级 语言