全国计算机二级C语言笔试历届真题汇编 超强整理可打印Word文件下载.docx
- 文档编号:22337270
- 上传时间:2023-02-03
- 格式:DOCX
- 页数:161
- 大小:97.55KB
全国计算机二级C语言笔试历届真题汇编 超强整理可打印Word文件下载.docx
《全国计算机二级C语言笔试历届真题汇编 超强整理可打印Word文件下载.docx》由会员分享,可在线阅读,更多相关《全国计算机二级C语言笔试历届真题汇编 超强整理可打印Word文件下载.docx(161页珍藏版)》请在冰豆网上搜索。
(12)以下关于简单程序设计的步骤和顺序的说法中正确的是
A)确定算法后,整理并写出文档,最后进行编码和上机调试
B)首先确定数据结构,然后确定算法,再编码,并上机调试,最后整理文档
C)先编码和上机调试,在编码过程中确定算法和数据结构,最后整理文档
D)先写好文档,再根据文档进行编码和上机调试,最后确定算法和数据结构
(13)以下叙述中错误的是
A)C程序在运行过程中所有计算都以二进制方式进行
B)C程序在运行过程中所有计算都以十进制方式进行
C)所有C程序都需要编译链接无误后才能运行
D)C程序中整型变量只能存放整数,实型变量只能存放浮点数
(14)有以下定义:
inta;
longb;
doublex,y;
则以下选项中正确的表达式是
A)a%(int)(x-y)
B)a=x!
=y;
C)(a*y)%b
D)y=x+y=x
(15)以下选项中能表示合法常量的是
A)整数:
1,200
B)实数:
1.5E2.0
C)字符斜杠:
‘\’
D)字符串:
"
\007"
(16)表达式a+=a-=a=9的值是
A)9B)_9
C)18D)0
(17)若变量已正确定义,在if(W)printf(“%d\n,k”);
中,以下不可替代W的是
A)a<>b+cB)ch=getchar()
C)a==b+cD)a++
(18)有以下程序
#include<
stdio.h>
main()
{inta=1,b=0;
if(!
a)b++;
elseif(a==0)if(a)b+=2;
elseb+=3;
printf(”%d\n”,b);
}
程序运行后的输出结果是
A)0B)1
C)2D)3
(19)若有定义语句inta,b;
doublex;
则下列选项中没有错误的是
A)switch(x%2)
B)switch((int)x/2.0
{case0:
a++;
break;
{case0:
case1:
b++;
case1:
default:
default:
}}
C)switch((int)x%2)
D)switch((int)(x)%2)
{case0.0:
case1.0:
(20)有以下程序
#include<
{inta=1,b=2;
while(a<
6){b+=a;
a+=2;
b%二10;
printf(”%d,%d\n”,a,b);
A)5,11B)7,1
C)7,11D)6,1
(21)有以下程序
#include<stdio.h>
{inty=10;
while(y--);
printf(”Y=%d\n”,Y);
程序执行后的输出结果是
A)y=0B)y=-1
C)y=1D)while构成无限循环
(22)有以下程序
#include<stdio.h>
{chars[」=”rstuv"
;
printf(”%c\n”,*s+2);
A)tuvB)字符t的ASCII码值
C)tD)出错
(23)有以下程序
#include<stdio.h>
#include<string.h>
{charx[]=”STRING”;
x[0」=0;
x[1]=’\0’;
x[2」=’0’;
printf(”%d%d\n”,sizeof(x),strlen(x));
A)61B)70
C)63D)71
(24)有以下程序
Intf(intx);
{intn=1,m;
m=f(f(f(n)));
printf(”%d\n”,m);
intf(intx)
{returnx*2;
A)1B)2
C)4D)8
(25)以下程序段完全正确的是
A)int*p;
scanf("
%d"
&p);
B)int*p;
scanf(“%d”,p);
C)intk,*p=&
k;
p);
D)intk,*p:
;
*p=&
(26)有定义语句:
int*p[4];
以下选项中与此语句等价的是
A)intp[4];
B)int**p;
C)int*(p「4」);
D)int(*p)「4」;
(27)下列定义数组的语句中,正确的是
A)intN=10;
B)#defineN10
intx[N];
intx[N];
C)intx[0..10];
D)intx[];
(28)若要定义一个具有5个元素的整型数组,以下错误的定义语句是
A)inta[5]=﹛0﹜;
B)intb[]={0,0,0,0,0};
C)intc[2+3];
D)inti=5,d[i];
(29)有以下程序
voidf(int*p);
{inta[5]={1,2,3,4,5},*r=a;
f(r);
printf(”%d\n”;
*r);
voidf(int*p)
{p=p+3;
printf(”%d,”,*p);
A)1,4B)4,4
C)3,1D)4,1
(30)有以下程序(函数fun只对下标为偶数的元素进行操作)
#include<stdio.h>
voidfun(int*a;
intn)
{inti、j、k、t;
for(i=0;
i<n一1;
1+=2)
{k=i;
‘
for(j=i;
j<
n;
j+=2)if(a[j]>
a〔k])k=j;
t=a〔i];
a〔i]=a[k];
a〔k]=t;
{intaa「10」={1、2、3、4、5、6、7},i;
fun(aa、7);
for(i=0,i<
7;
i++)printf(”%d,”,aa[i]));
printf(”\n”);
A)7,2,5,4,3,6,1
B)1,6,3,4,5,2,7
C)7,6,5,4,3,2,1
D)1,7,3,5,6;
2,1
(31)下列选项中,能够满足“若字符串s1等于字符串s2,则执行ST"
要求的是
A)if(strcmp(s2,s1)==0)ST;
B)if(sl==s2)ST;
C)if(strcpy(sl,s2)==1)ST;
D)if(sl-s2==0)ST;
(32)以下不能将s所指字符串正确复制到t所指存储空间的是
A)while(*t=*s){t++;
s++;
B)for(i=0;
t[i]=s[i];
i++);
C)do{*t++=*s++;
}while(*s);
D)for(i=0,j=0;
t[i++]=s[j++];
);
(33)有以下程序(strcat函数用以连接两个字符串)
#include<string.h>
{chara[20]=”ABCD\OEFG\0”,b[]=”IJK”;
strcat(a,b);
printf(”%s\n”,a);
A)ABCDE\OFG\OIJK
B)ABCDIJK
C)IJK
D)EFGIJK
(34)有以下程序,程序中库函数islower(ch)用以判断ch中的字母是否为小写字母
#include<ctype.h>
voidfun(char*p)
{inti=0;
while(p[i])
{if(p[i]==’’&&islower(p「i-1」))p[i-1]=p[i-1]-‘a’+‘A’;
i++;
{chars1[100]=”abcdEFG!
”;
fun(s1);
printf(”%s\n”,s1);
A)abcdEFG!
B)AbCdEFg!
C)aBcDEFG!
D)abcdEFg!
(35)有以下程序
voidfun(intx)
{if(x/2>1)fun(x/2);
printf(”%d”,x);
{fun(7);
printf(”\n”);
A)137B)731
C)73D)37
(36)有以下程序
#include<stdio.h>
intfun()
{staticintx=1;
x+=1;
returnx;
{inti;
s=1;
for(i=1;
i<
=5;
i++)s+=fun();
printf(”%d\n”,s);
A)11B)21
C)6D)120
(37)有以下程序
#inctude<stdio.h>
#include<stdlib.h>
Main()
{int*a,*b,*c;
a=b=c=(int*)malloc(sizeof(int));
*a=1;
*b=2,*c=3;
a=b;
printf(“%d,%d,%d\n”,*a,*b,*c);
A)3,3,3B)2,2,3
C)1,2,3D)1,1,3
(38)有以下程序
{ints,t,A=10;
doubleB=6;
s=sizeof(A);
t=sizeof(B);
printf(“%d,%d\n”,s,t);
在VC6平台上编译运行,程序运行后的输出结果是
A)2,4B)4,4C)4,8D)10,6
(39)若有以下语句
TypedefstructS
{intg;
charh;
}T;
以下叙述中正确的是
A)可用S定义结构体变量
B)可用T定义结构体变量
C)S是struct类型的变量
D)T是structS类型的变量
(40)有以下程序
{shortc=124;
c=c_______;
printf(“%d\n”、C);
若要使程序的运行结果为248,应在下划线处填入的是
A)>
>
2B)|248C)&0248D)<
<
I
二、填空题(每空2分,共30分)
(1)一个栈的初始状态为空。
首先将元素5,4,3,2,1依次入栈,然后退栈一次,再将元素A,
B,C,D依次入栈,之后将所有元素全部退栈,则所有元素退栈(包括中间退栈的元素)的顺序为【1】
(2)在长度为n的线性表中,寻找最大项至少需要比较【2】次。
(3)一棵二叉树有10个度为1的结点,7个度为2的结点,则该二叉树共有【3】个结点。
(4)仅由顺序、选择(分支)和重复(循环)结构构成的程序是【4】程序。
(5)数据库设计的四个阶段是:
需求分析,概念设计,逻辑设计【5】。
(6)以下程序运行后的输出结果是【6】。
{inta=200,b=010;
printf(”%d%d\n”,a,b);
(7)有以下程序
{intx,Y;
scanf(”%2d%ld”,&x,&y);
printf(”%d\n”,x+y);
程序运行时输入:
1234567程序的运行结果是【7】。
(8)在C语言中,当表达式值为0时表示逻辑值“假”,当表达式值为【8】时表示逻辑值“真”。
(9)有以下程序
{inti,n[]={0,0,0,0,0};
for(i=1;
=4;
i++)
{n[i]=n[i-1]*3+1;
printf(”%d"
n[i]);
}
程序运行后的输出结果是【9】。
(10)以下fun函数的功能是:
找出具有N个元素的一维数组中的最小值,并作为函数值返
回。
请填空。
(设N已定义)
intfun(intx[N])
{inti,k=0;
for(i=0;
N;
I++)
if(x[i]
returnx[k];
(11)有以下程序
#include<stdio.h>
int*f(int*p,int*q);
{intm=1,n=2,*r=&
m;
r=f(r,&n);
printf(”%d\n”,*r);
int*f(int*p,int*q)
{return(*p>
*q)?
p:
q;
程序运行后的输出结果是【11】
(12)以下fun函数的功能是在N行M列的整形二维数组中,选出一个最大值作为函数值
返回,请填空。
(设M,.N已定义)
intfun(inta[N][M))
{inti,j,row=0,col=0;
for(j=0;
j
if(a[i][j]>a[row][col]){row=i;
col=j;
return(【12】):
(13)有以下程序
{intn[2],i,j;
2;
i++)n[i]=0;
i<2;
j++)n[j]=n「i」+1;
printf(”%d\n”,n[1]);
程序运行后的输出结果是【13】
(14)以下程序的功能是:
借助指针变量找出数组元素中最大值所在的位置并输出该最大值。
请在输出语句中填写代表最大值的输出项。
{inta〔10],*p,*s;
for(p=a;
p-a<
10;
p++)scanf(”%d”,p);
for(p=a,s=a;
p++)if(*p>
*s)S=P;
printf("
max=%d\n”,【14】);
(15)以下程序打开新文件f.txt,并调用字符输出函数将a数组中的字符写入其中,请填空。
{【15】*fp;
chara[5]={’1’,’2’,’3’,’4’,’5’},i;
fp=fopen(”f.txt”,”w”);
5;
i++)fputc(a[i],fp);
fclose(fp);
2010年3月全国计算机二级C语言
一、选择题
(1)下列叙述中正确的是
A)对长度为n的有序链表进行查找,最坏情况下需要的比较次数为n
B)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)
C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(
)
D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n
(2)算法的时间复杂度是指
A)算法的执行时间
B)算法所处理的数据量
C)算法程序中的语句或指令条数
D)算法在执行过程中所需要的基本运算次数
(3)软件按功能可以分为:
应用软件、系统软件和支撑软件(或工具软件)。
下面属于系统软件的是
A)编辑软件B)操作系统
C)教务管理系统D)浏览器
(4)软件(程序)调试的任务是
A)诊断和改正程序中的错误
B)尽可能多地发现程序中的错误
C)发现并改正程序中的所有错误
D)确定程序中错误的性质
(5)数据流程图(DFD图)是
A)软件概要设计的工具
B)软件详细设计的工具
C)结构化方法的需求分析工具
D)面向对象方法的需求分析工具
(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。
详细设计属于
A)定义阶段B)开发阶段
C)维护阶段D)上述三个阶段
(7)数据库管理系统中负责数据模式定义的语言是
A)数据定义语言
B)数据管理语言
C)数据操纵语言
D)数据控制语言
(8)在学生管理的关系数据库中,存取一个学生信息的数据单位是
A)文件B)数据库
C)字段D)记录
(9)数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的
A)需求分析阶段
B)逻辑设计阶段
C)概念设计阶段
D)物理设计阶段
(10)有两个关系R和T如下:
A
B
C
a
1
2
b
c
3
d
RT
则由关系R得到关系T的操作是
A)选择B)投影C)交D)并
(11)以下叙述正确的是
A)C语言程序是由过程和函数组成的
B)C语言函数可以嵌套调用,例如:
fun(fun(x))
C)C语言函数不可以单独编译
D)C语言中除了main函数,其他函数不可以作为单独文件形式存在
(12)以下关于C语言的叙述中正确的是
A)C语言中的注释不可以夹在变量名或关键字的中间
B)C语言中的变量可以再使用之前的任何位置进行定义
C)在C语言算术的书写中,运算符两侧的运算数类型必须一致
D)C语言的数值常量中夹带空格不影响常量值的正确表示
(13)以下C语言用户标示符中,不合法的是
A)_1B)AaBcC)a_bD)a--b
(14)若有定义:
doublea=22;
inti=0,k=18;
则不符合C语言规定的赋值语句是
A)a=a++,i++B)i=(a+k)<
=(i+k)
C)i=a%11D)i=!
(15)
{
chara,b,c,d;
scanf("%c%c",&
a,&
b);
c=getchar();
d=getchar();
printf("%c%c%c%c\n",a,b,c,d);
当执行程序时,按下列方式输入数据(从第一列开始,<
CR>
代表回车,注意:
回车是一个字符)
12<
34<
则输出结果是:
A、1234B、12
C、12D、12
334
16、以下关于C语言数据类型使用的叙述中错误的是:
A、若要准确无误的表示自然数,应使用整数类型。
B、若要保存带有多位小数的数据,应使用双精度类型。
C、若要处理如"人员信息"等含有不同类型的相关数据,应自定义结构体类型。
D、若只处理"真"和"假"两种逻辑值,应使用逻辑类型。
17、若a是数值类型,则逻辑表达式(a==1)||(a!
=1)的值是:
A、1B、0
C、2D、不知道a的值,不能确定
18、以下选项中与if(a==1)a=b;
elsea++;
语句功能不同的switch语句是:
A、switch(a)B、switch(a==1)
{case1:
a=b;
break;
{case0:
a=b;
case1:
C、switch(a)D、switch(a==1)
{default:
case0:
19、有如下嵌套的if语句
if(a<
b)
c)k=a;
elsek=c;
else
if(b<
c)k=b;
elsek=c;
以下选项中与上述if语句等价的语句是
A、k=(a<
b)?
a:
b;
k=(b<
c)?
b:
c;
B、k=(a<
((b<
b):
c);
C、k=(a<
((a<
c):
D、k=(a<
k=(a<
a;
#include<
{inti,j,m=1;
for(i=1;
3;
{for(j=3;
j>
0;
j--)
{if(i*j>
3)break;
m*=i*j;
printf("m=%d\n",m)
(A)m=6(B)m=2
(C)m=4
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 全国计算机二级C语言笔试历届真题汇编 超强整理可打印 全国计算机 二级 语言 笔试 历届 汇编 超强 整理 打印