131415年全国计算机等级考试二级C语言笔试真题与答案三套卷Word文档格式.docx
《131415年全国计算机等级考试二级C语言笔试真题与答案三套卷Word文档格式.docx》由会员分享,可在线阅读,更多相关《131415年全国计算机等级考试二级C语言笔试真题与答案三套卷Word文档格式.docx(39页珍藏版)》请在冰豆网上搜索。
![131415年全国计算机等级考试二级C语言笔试真题与答案三套卷Word文档格式.docx](https://file1.bdocx.com/fileroot1/2022-11/30/88bb7ada-1c90-4ed3-b2a2-c0c084f927dc/88bb7ada-1c90-4ed3-b2a2-c0c084f927dc1.gif)
(14)以下选项中可用作C程序合法实数的是
A).1e0B)3.0e0.2C)E9D)9.12E
(15)若有定义语句:
inta=3,b=2,c=1;
,以下选项中错误的赋值表达式是
A)a=(b=4)=3;
B)a=b=c+1;
C)a=(b=4)+c;
D)a=1+(b=c=4);
(16)有以下程序段charname[20];
intnum;
scanf("
name=%snum=%d"
name;
&
num);
当执行上述程序段,并从键盘输入:
name=Lilinum=1001<
回车>
后,name的值为
A)LiliB)name=Lili
C)Lilinum=D)name=Lilinum=1001
(17)if语句的基本形式是:
if(表达式)语句,以下关于“表达式”值的叙述中正确的是
A)必须是逻辑值B)必须是整数值
C)必须是正数D)可以是任意合法的数值
(18)有以下程序
#includemain()
{intx=011;
printf("
%d\n"
++x);
}
程序运行后的输出结果是
A)12B)11C)10D)9
(19)有以下程序
#include<
stdio.h>
main()
{ints;
scanf("
%d"
&
s);
while(s>
0)
{switch(s)
{case1:
s+5);
case2:
s+4);
break;
case3:
s+3);
default:
%d"
s+1);
break;
运行时,若输入123450<
,则输出结果是
A)6566456B)66656C)66666D)6666656
(20)有以下程序段inti,n;
for(i=0;
i<
8;
i++)
{n=rand()%5;
switch(n)
case3:
n);
case4:
continue;
case0:
exit(0);
}以下关于程序段执行情况的叙述,正确的是
A)for循环语句固定执行8次
B)当产生的随机数n为4时结束循环操作
C)当产生的随机数n为1和2时不做任何操作
D)当产生的随机数n为0时结束程序运行
(21)有以下程序
{chars[]="
012xy\08s34f4w2"
;
inti,n=0;
for(i=0;
s[i]!
=0;
if(s[i]>
='
0'
s[i]<
9'
)n++;
A)0B)3C)7D)8
(22)若i和k都是int类型变量,有以下for语句
for(i=0,k=-1;
k=1;
k++)printf("
*****\n"
);
下面关于语句执行情况的叙述中正确的是
A)循环体执行两次
B)循环体执行一次
C)循环体一次也不执行
D)构成无限循环
(23)有以下程序
{charb,c;
inti;
b='
a'
c='
A'
6;
{if(i%2)putchar(i+b);
elseputchar(i+c);
\n"
A)ABCDEFB)AbCdEfC)aBcDeFD)abcdef
(24)设有定义:
doublex[10],*p=x;
,以下能给数组x下标为6的元素读入数据的正确语句是
A)scanf("
%f"
x[6]);
B)scanf("
%lf"
*(x+6));
C)scanf("
p+6);
D)scanf("
p[6]);
(25)有以下程序(说明:
字母A的ASCII码值是65)
voidfun(char*s)
{while(*s)
{if(*s%2)printf("
%c"
*s);
s++;
{chara[]="
BYTE"
fun(a);
A)BYB)BTC)YTD)YE
(26)有以下程序段
{„
while(getchar()!
\n'
„
以下叙述中正确的是
A)此while语句将无限循环
B)getchar()不可以出现在while语句的条件表达式中
C)当执行此while语句时,只有按回车键程序才能继续执行
D)当执行此while语句时,按任意键程序就能继续执行
(27)有以下程序
{intx=1,y=0;
if(!
x)y++;
elseif(x==0)
if(x)y+=2;
elsey+=3;
y);
A)3B)2C)1D)0
(28)若有定义语句:
chars[3][10],(*k)[3],*p;
,则以下赋值语句正确的是
A)p=s;
B)p=k;
C)p=s[0];
D)k=s;
(29)有以下程序
voidfun(char*c)
{while(*c)
{if(*c>
*c<
z'
)*c=*c-('
-'
c++;
{chars[81];
gets(s);
fun(s);
puts(s);
当执行程序时从键盘上输入HelloBeijing<
,则程序的输出结果是
A)hellobeijingB)HelloBeijing
C)HELLOBEIJINGD)hELLOBeijing
(30)以下函数的功能是:
通过键盘输入数据,为数组中的所有元素赋值。
#defineN10
voidfun(intx[N])
{inti=0;
while(i<
N)scanf(“%d”,);
在程序中下划线处应填入的是
A)x+iB)&
x[i+1]C)x+(i++)D)&
x[++i]
(31)有以下程序
{chara[30],b[30];
%s"
a);
gets(b);
%s\n%s\n"
a,b);
程序运行时若输入:
howareyou?
Iamfine<
则输出结果是
A)howareyou?
B)howIamfineareyou?
Iamfine
C)howareyou?
Iamfine
D)howareyou?
(32)设有如下函数定义
intfun(intk)
{if(k<
1)return0;
elseif(k==1)return1;
elsereturnfun(k-1)+1;
若执行调用语句:
n=fun(3);
,则函数fun总共被调用的次数是
A)2B)3C)4D)5
(33)有以下程序
intfun(intx,inty)
{if(x!
=y)return((x+y)/2);
elsereturn(x);
{inta=4,b=5,c=6;
fun(2*a,fun(b,c)));
A)3B)6C)8D)12
(34)有以下程序
intfun()
{staticintx=1;
x*=2;
returnx;
{inti,s=1;
for(i=1;
=3;
i++)s*=fun();
s);
A)0B)10C)30D)64
(35)有以下程序
#defineS(x)4*(x)*x+1main()
{intk=5,j=2;
S(k+j));
A)197B)143C)33D)28
(36)设有定义:
struct{charmark[12];
intnum1;
doublenum2;
}t1,t2;
,若变量均已正确赋初值,则以下语句中错误的是
A)t1=t2;
B)t2.num1=t1.num1;
C)t2.mark=t1.mark;
D)t2.num2=t1.num2;
(37)有以下程序
structord
{intx,y;
}dt[2]={1,2,3,4};
{
structord*p=dt;
%d,"
++(p->
x));
printf("
y));
A)1,2B)4,1C)3,4D)2,3
(38)有以下程序
structS
{inta,b;
}data[2]={10,100,20,200};
{structSp=data[1];
++(p.a));
A)10B)11C)20D)21
(39)有以下程序
{unsignedchara=8,c;
c=a>
>
3;
c);
A)32B)16C)1D)0
(40)设fp已定义,执行语句fp=fopen("
file"
"
w"
后,以下针对文本文件file操作叙述的选项中正确的是
A)写操作结束后可以从头开始读B)只能写不能读
C)可以在原有内容后追加写D)可以随意读和写
二、填空题
(1)有序线性表能进行二分查找的前提是该线性表必须是【有序】存储的。
(2)一棵二叉树的中序遍历结果为DBEAFC,前序遍历结果为ABDECF,则后序遍历结果为
【DEBFCA】。
(3)对软件设计的最小单位(模块或程序单元)进行的测试通常称为【单元】测试。
(4)实体完整性约束要求关系数据库中元组的【主键】属性值不能为空。
(5)在关系A(S,SN,D)和关系B(D,CN,NM)中,A的主关键字是S,B的主关键字是D,则称【D】是关系A的外码。
(6)以下程序运行后的输出结果是【3】。
#include<
{inta;
a=(int)((double)(3/2)+0.5+(int)1.99*2);
(7)有以下程序
{intx;
x);
if(x>
15)printf("
x-5);
10)printf("
x);
5)printf("
x+5);
若程序运行时从键盘输入12<
,则输出结果为【1217】。
(8)有以下程序(说明:
字符0的ASCII码值为48)
{charc1,c2;
c1);
c2=c1+9;
%c%c\n"
c1,c2);
若程序运行时从键盘输入48<
,则输出结果为【09】。
(9)有以下函数
voidprt(charch,intn)
{inti;
=n;
printf(i%6!
=0?
"
:
%c\n"
ch);
执行调用语句prt('
*'
24);
后,函数共输出了【4】行*号。
(10)以下程序运行后的输出结果是【200】。
{intx=10,y=20,t=0;
if(x==y)t=x;
x=y;
y=t;
%d%d\n"
x,y);
(11)己知a所指的数组中有N个元素。
函数fun的功能是,将下标k(k>
0)开始的后续元素全
部向前移动一个位置。
请填空。
voidfun(inta[N],intk)
for(i=k;
N;
i++)a[【i-1】]=a[i];
(12)有以下程序,请在【12】处填写正确语句,使程序可正常编译运行。
【doubleavg(double,double);
或doubleavg(doublea,doubleb);
】;
{doublex,y,(*p)();
%lf%lf"
x,&
y);
p=avg;
%f\n"
(*p)(x,y));
doubleavg(doublea,doubleb)
{return((a+b)/2);
(13)以下程序运行后的输出结果是【13715】。
{inti,n[5]={0};
=4;
{n[i]=n[i-1]*2+1;
n[i]);
}
(14)以下程序运行后的输出结果是【emoclew】。
stdlib.h>
string.h>
{char*p;
p=(char*)malloc(sizeof(char)*20);
strcpy(p,"
welcome"
for(i=6;
i>
i--)putchar(*(p+i));
free(p);
(15)以下程序运行后的输出结果是【123456】。
{FILE*fp;
intx[6]={1,2,3,4,5,6},i;
fp=fopen("
test.dat"
wb"
fwrite(x,sizeof(int),3,fp);
rewind(fp);
fread(x,sizeof(int),3,fp);
i++)printf("
x[i]);
fclose(fp);
参考答案
一、选择题:
1-5ABDDB6-10ACDCB
11-15ADAAA16-20ADCAD
21-25BDBCD26-30CDCCC
31-35BBBDB36-40CDDCB
二、填空题:
【1】有序【2】DEBFCA【3】单元
【4】主键【5】D【6】3
【7】1217【8】09【9】4
【10】200【11】i-1
【12】doubleavg(double,double);
【13】13715【14】emoclew【15】123456
2013年3月全国计算机等级考试二级C语言笔试试题
一、选择题
在下列各题的A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选项涂写在答题卡相应位置上,答在试卷上不得分。
(1)为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为
A)PAD图B)N-S图C)结构图D)数据流图
(2)结构化程序设计主要强调的是
A)程序的规模B)程序的效率C)程序设计语言的先进性D)程序易读性
(3)为了使模块尽可能独立,要求
A)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量强
B)模块的内聚程度要尽量高,且各模块间的耦合程度要尽量弱
C)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量弱
D)模块的内聚程度要尽量低,且各模块间的耦合程度要尽量强
(4)需求分析阶段的任务是确定
A)软件开发方法B)软件开发工具C)软件开发费用D)软件系统功能
(5)算法的有穷性是指
A)算法程序的运行时间是有限的
B)算法程序所处理的数据量是有限的
C)算法程序的长度是有限的
D)算法只能被有限的用户使用
(6)对长度为n的线性表排序,在最坏情况下,比较次数不是n(n-1)/2的排序方法是
A)快速排序B)冒泡排序C)直接插入排序D)堆排序
(7)如果进栈序列为e1,e2,e3,e4,则可能的出栈序列是
A)e3,e1,e4,e2B)e2,e4,e3,e1C)e3,e4,e1,e2D)任意顺序
【解析】由栈"
后进先出"
的特点可知:
A)中e1不可能比e2先出,C)中e1不可能比e2先出,D)中栈是先进后出的,所以不可能是任意顺序
(8)将E-R图转换到关系模式时,实体与联系都可以表示成
A)属性B)关系C)键D)域
(9)有三个关系R、S和T如下:
R
BCD
a0k1
b1n1
S
f3h2
n2x1
T
BCD
a0k1
由关系R和S通过运算得到关系T,则所使用的运算为
A)并B)自然连接C)笛卡尔积D)交
(10)下列有关数据库的描述,正确的是
A)数据处理是将信息转化为数据的过程
B)数据的物理独立性是指当数据的逻辑结构改变时,数据的存储结构不变
C)关系中的每一列称为元组,一个元组就是一个字段
D)如果一个关系中的属性或属性组并非该关系的关键字,但它是另一个关系的关键字,则称其为本关系的外关键字
(11)以下叙述中正确的是
A)用C程序实现的算法必须要有输入和输出操作
B)用C程序实现的算法可以没有输出但必须要有输入
C)用C程序实现的算法可以没有输入但必须要有输出
D)用C程序实现的算法可以既没有输入也没有输出
【解析】算法具有的5个特性是:
有穷性;
确定性;
可行性;
有0个或多个输入;
有一个或多个输出。
所以说,用C程序实现的算法可以没有输入但必须要有输出。
(12)下列可用于C语言用户标识符的一组是
A)void,define,WORDB)a3_3,_123,CarC)For,-abc,IFCaseD)2a,DO,sizeof
【解析】C语言规定标识符只能由字母、数字和下划线3种字符组成,且第一个字符必须为字母或下划线,排除选项C)和D);
C语言中还规定标识符不能为C语言的关键字,而选项A)中void为关键字,故排除选项A)。
(13)以下选项中可作为C语言合法常量的是
A)-80B)-080C)-8e1.0D)-80.0e
【解析】选项B)项中,以0开头表示是一个八进制数,而八进制数的取值范围是0~7,所以-080是不合法的;
选项C)和D)中,e后面的指数必须是整数,所以也不合法
(14)若有语句:
c