全国计算机等级考试二级笔试样卷c语言程序设计.docx
《全国计算机等级考试二级笔试样卷c语言程序设计.docx》由会员分享,可在线阅读,更多相关《全国计算机等级考试二级笔试样卷c语言程序设计.docx(15页珍藏版)》请在冰豆网上搜索。
![全国计算机等级考试二级笔试样卷c语言程序设计.docx](https://file1.bdocx.com/fileroot1/2023-4/24/60569f81-1023-4070-a296-3bc169084288/60569f81-1023-4070-a296-3bc1690842881.gif)
全国计算机等级考试二级笔试样卷c语言程序设计
全国计算机等级考试二级笔试样卷C语言程序设计
一、选择题〔〔1〕~〔10〕、〔21〕~〔40〕每题2分,〔11〕~〔20〕每题2分,共70分〕
以下各题A〕、B〕、C〕、D〕四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。
〔1〕以下选项中不符合良好程序设计风格的是
A〕源程序要文档化B〕数据说明的次序要标准化
C〕防止滥用goto语句D〕模块设计要保证高耦合、高内聚
〔2〕从工程管理角度,软件设计一般分为两步完成,它们是
A〕概要设计与详细设计B〕数据设计与接口设计
C〕软件构造设计与数据设计D〕过程设计与数据设计
〔3〕以下选项中不属于软件生命周期开发阶段任务的是
A〕软件测试B〕概要设计C〕软件维护D〕详细设计
〔4〕在数据库系统中,用户所见的数据形式为
A〕概念形式B〕外形式C〕内形式D〕物理形式
〔5〕数据库设计的四个阶段是:
需求分析、概念设计、逻辑设计和
A〕编码设计B〕测试阶段C〕运行阶段D〕物理设计
〔6〕设有如下三个关系表
R
S
T
A
B
C
A
B
C
m
1
3
m
1
3
n
n
1
3
以下操作中正确的选项是
A〕T=R∩SB〕T=R∪S
C〕T=R×SD〕T=R/S
〔7〕以下表达中正确的选项是
A〕一个算法的空间复杂度大,那么其时间复杂度也必定大
B〕一个算法的空间复杂度大,那么其时间复杂度必定小
C〕一个算法的时间复杂度大,那么其空间复杂度必定小
D〕上述三种说法都不对
〔8〕在长度为64的有序线性表中进展顺序查找,最坏情况下需要比较的次数为
A〕63B〕64C〕6D〕7
〔9〕数据库技术的根本目的是要解决数据的
A〕存储问题B〕共享问题C〕平安问题D〕保护问题
〔10〕对以下二叉树
进展中序遍历的结果是
A〕ACBDFEGB〕ACBDFGEC〕ABDCGEFD〕FCADBEG
〔11〕以下表达中错误的选项是
A〕一个C语言程序只能实现一种算法
B〕C程序可以由多个程序文件组成
C〕C程序可以由一个或多个函数组成
D〕一个C函数可以单独作为一个C程序文件存在
〔12〕以下表达中正确的选项是
A〕每个C程序文件中都必需要有一个main()函数
B〕在C程序中main()函数的位置是固定的
C〕C程序中所有函数之间都可以互相调用,与函数所在位置无关
D〕在C程序的函数中不能定义另一个函数
〔13〕以下定义变量的语句中错误的选项是
A〕int_int;B〕doubleint_;C〕charFor;D〕floatUS$;
〔14〕假设变量x、y已正确定义并赋值,以下符合C语言语法的表达式是
A〕++x,y=x--B〕x+1=yC〕x=x+10=x+yD〕double(x)/10
〔15〕以下关于逻辑运算符两侧运算对象的表达中正确的选项是
A〕只能是整数0或1B〕只能是整数0或非0整数
C〕可以是构造体类型的数据D〕可以是任意合法的表达式
〔16〕假设有定义intx,y;并已正确给变量赋值,那么以下选项中与表达式(x-y)?
(x++):
(y++)中的条件表达式(x-y)等价的是
A〕(x-y>0)B〕(x-y<0)C〕(x-y<0||x-y>0)D〕(x-y==0)
〔17〕有以下程序
main()
{intx,y,z;
x=y=1;
z=x++,y++,++y;
printf("%d,%d,%d\n",x,y,z);
}
程序运行后的输出结果是
A〕2,3,3B〕2,3,2C〕2,3,1D〕2,2,1
〔18〕设有定义:
inta;floatb;执行scanf("%2d%f",&a,&b);语句时,假设从键盘输入876543.0<回车>,a和b的值分别是
〔19〕有以下程序
main()
{inta=0,b=0;
a=10;/*给a赋值
b=20;给b赋值*/
printf("a+b=%d\n",a+b);/*输出计算结果*/
}
程序运行后的输出结果是
A〕a+b=10B〕a+b=30C〕30D〕出错
〔20〕在嵌套使用if语句时,C语言规定else总是
A〕和之前与其具有一样缩进位置的if配对
B〕和之前与其最近的if配对
C〕和之前与其最近的且不带else的if配对
D〕和之前的第一个if配对
〔21〕以下表达中正确的选项是
A〕break语句只能用于switch语句
B〕在switch语句中必须使用default
C〕break语句必须与switch语句中的case配对使用
D〕在switch语句中,不一定使用break语句
〔22〕有以下程序
main()
{intk=5;
while(--k)printf("%d",k-=3);
printf("\n");
}
执行后的输出结果是
A〕1B〕2C〕4D〕死循环
〔23〕有以下程序
main()
{inti;
for(i=1;i<=40;i++)
{if(i++%5==0)
if(++i%8==0)printf("%d",i);
}
printf("\n");
}
执行后的输出结果是
A〕5B〕24C〕32D〕40
〔24〕以下选项中,值为1的表达式是
A〕1–'0'B〕1-'\0'C〕'1'-0D〕'\0'-'0'
〔25〕有以下程序
fun(intx,inty){return(x+y);}
main()
{inta=1,b=2,c=3,sum;
sum=fun((a++,b++,a+b),c++);
printf("%d\n",sum);
}
执行后的输出结果是
A〕6B〕7C〕8D〕9
〔26〕有以下程序
main()
{chars[]="abcde";
s+=2;
printf("%d\n",s[0]);
}
执行后的结果是
A〕输出字符a的ASCII码B〕输出字符c的ASCII码
C〕输出字符cD〕程序出错
〔27〕有以下程序
fun(intx,inty)
{staticintm=0,i=2;
i+=m+1;m=i+x+y;returnm;
}
main()
{intj=1,m=1,k;
k=fun(j,m);printf("%d,",k);
k=fun(j,m);printf("%d\n",k);
}
执行后的输出结果是
A〕5,5B〕5,11C〕11,11D〕11,5
〔28〕有以下程序
fun(intx)
{intp;
if(x==0||x==1)return(3);
p=x-fun(x-2);
returnp;
}
main()
{printf("%d\n",fun(7));}
执行后的输出结果是
A〕7B〕3C〕2D〕0
〔29〕在16位编译系统上,假设有定义inta[]={10,20,30},*p=&a;,当执行p++;后,以下说法错误的选项是
A〕p向高地址移了一个字节B〕p向高地址移了一个存储单元
C〕p向高地址移了两个字节D〕p与a+1等价
〔30〕有以下程序
main()
{inta=1,b=3,c=5;
int*p1=&a,*p2=&b,*p=&c;
*p=*p1*(*p2);
printf("%d\n",c);
}
执行后的输出结果是
A〕1B〕2C〕3D〕4
〔31〕假设有定义:
intw[3][5];,那么以下不能正确表示该数组元素的表达式是
A〕*(*w+3)B〕*(w+1)[4]C〕*(*(w+1))D〕*(&w[0][0]+1)
〔32〕假设有以下函数首部
intfun(doublex[10],int*n)
那么下面针对此函数的函数声明语句中正确的选项是
A〕intfun(doublex,int*n);B〕intfun(double,int);
C〕intfun(double*x,intn);D〕intfun(double*,int*);
〔33〕有以下程序
voidchange(intk[]){k[0]=k[5];}
main()
{intx[10]={1,2,3,4,5,6,7,8,9,10},n=0;
while(n<=4){change(&x[n]);n++;}
for(n=0;n<5;n++)printf("%d",x[n]);
printf("\n");
}
程序运行后输出的结果是
A〕678910B〕13579C〕12345D〕62345
〔34〕有以下程序
main()
{intx[3][2]={0},i;
for(i=0;i<3;i++)scanf("%d",x[i]);
printf("%3d%3d%3d\n",x[0][0],x[0][1],x[1][0]);
}
假设运行时输入:
246<回车>,那么输出结果为
A〕200B〕204C〕240D〕246
〔35〕有以下程序
intadd(inta,intb){return(a+b);}
main()
{intk,(*f)(),a=5,b=10;
f=add;
…
}
那么以下函数调用语句错误的选项是
A〕k=(*f)(a,b);B〕k=add(a,b);
C〕k=*f(a,b);D〕k=f(a,b);
〔36〕有以下程序
#include
main(intargc,char*argv[])
{inti=1,n=0;
while(i
printf("%d\n",n);
}
该程序生成的可执行文件名为:
proc.exe。
假设运行时输入命令行:
proc1234567
那么程序的输出结果是
A〕3B〕5C〕7D〕11
〔37〕有以下程序
#include
#defineN5
#defineMN+1
#definef(x)(x*M)
main()
{inti1,i2;
i1=f
(2);
i2=f(1+1);
printf("%d%d\n",i1,i2);
}
程序的运行结果是
A〕1212B〕117C〕1111D〕127
〔38〕有以下构造体说明、变量定义和赋值语句
structSTD
{charname[10];
intage;
charsex;
}s[5],*ps;
ps=&s[0];
那么以下scanf函数调用语句中错误引用构造体变量成员的是
A〕scanf("%s",s[0].name);B〕scanf("%d",&s[0].age);
C〕scanf("%c",&(ps->sex));D〕scanf("%d",ps->age);
〔39〕假设有以下定义和语句
uniondata
{inti;charc;floatf;}x;
inty;
那么以下语句正确的选项是
A〕x=10.5;B〕x.c=101;C〕y=x;D〕printf("%d\n",x);
〔40〕有以下程序
#include
main()
{FILE*fp;inti;
charch[]="abcd",t;
fp=fopen("abc.dat","wb+");
for(i=0;i<4;i++)fwrite(&ch[i],1,1,fp);
fseek(fp,-2L,SEEK_END);
fread(&t,1,1,fp);
fclose(fp);
printf("%c\n",t);
}
程序执行后的输出结果是
A〕dB〕cC〕bD〕a
二、填空题〔每空2分,共30分〕
请将每一个空的正确答案写在答题卡【1】至【15】序号的横线上,答在试卷上不得分。
〔1〕以下软件系统构造图
的宽度为【1】。
〔2〕【2】的任务是诊断和改正程序中的错误。
〔3〕一个关系表的行称为【3】。
〔4〕按“先进后出〞原那么组织数据的数据构造是【4】。
〔5〕数据构造分为线性构造和非线性构造,带链的队列属于【5】。
〔6〕设有定义:
floatx=123.4567;,那么执行以下语句后的输出结果是【6】。
printf("%f\n",(int)(x*100+0.5)/100.0);
〔7〕以下程序运行后的输出结果是【7】。
main()
{intm=011,n=11;
printf("%d%d\n",++m,n++);
}
〔8〕以下程序运行后的输出结果是【8】。
main()
{intx,a=1,b=2,c=3,d=4;
x=(a x=(x x=(d>x)?
x:
d;
printf("%d\n",x);
}
〔9〕有以下程序,假设运行时从键盘输入:
18,11<回车>,那么程序的输出结果是【9】。
main()
{inta,b;
printf("Entera,b:
");scanf("%d,%d",&a,&b);
while(a!
=b)
{while(a>b)a-=b;
while(b>a)b-=a;
}
printf("%3d%3d\n",a,b);
}
〔10〕以下程序的功能是:
将输入的正整数按逆序输出。
例如:
假设输入135那么输出531。
请填空。
#include
main()
{intn,s;
printf("Enteranumber:
");scanf("%d",&n);
printf("Output:
");
do
{s=n%10;printf("%d",s);【10】;}
while(n!
=0);
printf("\n");
}
〔11〕以下程序中,函数fun的功能是计算x2-2x+6,主函数中将调用fun函数计算:
y1=(x+8)2-2(x+8)+6
y2=sin2(x)-2sin(x)+6
请填空。
#include"math.h"
doublefun(doublex){return(x*x-2*x+6);}
main()
{doublex,y1,y2;
printf("Enterx:
");scanf("%lf",&x);
y1=fun(【11】);
y2=fun(【12】);
printf("y1=%lf,y2=%lf\n",y1,y2);
}
〔12〕下面程序的功能是:
将N行N列二维数组中每一行的元素进展排序,第0行从小到大排序,第1行从大到小排序,第2行从小到大排序,第3行从大到小排序,例如:
#defineN4
voidsort(inta[][N])
{inti,j,k,t;
for(i=0;i
for(j=0;j
for(k=【13】;k
/*判断行下标是否为偶数来确定按升序或降序来排序*/
if(【14】?
a[i][j]a[i][k])
{t=a[i][j];
a[i][j]=a[i][k];
a[i][k]=t;
}
}
voidoutarr(inta[N][N])
{……}
main()
{intaa[N][N]={{2,3,4,1},{8,6,5,7},{11,12,10,9},{15,14,16,13}};
outarr(aa);/*以矩阵的形式输出二维数组*/
sort(aa);
outarr(aa);
}
〔13〕下面程序的运行结果是:
【15】。
#include
intf(inta[],intn)
{if(n>1)
returna[0]+f(a+1,n-1);
else
returna[0];
}
main()
{intaa[10]={1,2,3,4,5,6,7,8,9,10},s;
s=f(aa+2,4);printf("%d\n",s);