C语言考试试题基础版文档格式.docx
《C语言考试试题基础版文档格式.docx》由会员分享,可在线阅读,更多相关《C语言考试试题基础版文档格式.docx(25页珍藏版)》请在冰豆网上搜索。
11.C语言中,表示一条语句结束的标号是
A.#B.;
C.//D.}
12.每个C程序中都必须有且仅有一个
A.类B.预处理命令C.主函数D.语句
13.下列数据类型不是C语言基本数据类型的是。
A.字符型B.整型C.实型D.数组
14.下列字符列中,可作为C语言程序自定义标识符是。
A.switchB.fileC.breakD.do
15.运算符+、<
=、=、%中,优先级最低的运算符是。
A.+B.<
=C.=D.%
16.下列字符列中,可以作为“字符串常量”的是。
A.ABCB.″xyz″C.′uvw′D.′a′
17.字符串"
vm\x43\\\np\102q"
的长度是。
A.8B.10C.17D.16
18.
在C语言中,自定义的标识符。
A.能使用关键字并且不区分大小写
B.不能使用关键字并且不区分大小写
C.能使用关键字并且区分大小写
D.不能使用关键字并且区分大小写
19.设x和y均为逻辑型变量,则x&
&
y为真的条件是
A.它们均为真
B.其中一个为真
C.它们均为假
D.其中一个为假
20.若给定条件表达式(m)?
(a++):
(a--),则其中表达式m。
A.和(m==0)等价B.和(m==1)等价
C.和(m!
=0)等价D.和(m!
=1)等价
21.在if语句中,用作判断的表达式为。
A.关系表达式B.逻辑表达式
C.算术表达式D.任意表达式
22.设i和k都是int类型,则以下for循环语句。
for(i=0,k=-1;
k=1;
i++,k++)printf("
****\n"
);
A.判断循环结束的条件不合法B.是无限循环
C.循环体一次也不执行D.循环体只执行一次
23.若有以下语句,则输出结果为。
inta=2,b=1;
strings1;
s1=a>
b?
"
a大于b"
:
a小于b"
;
printf("
%s\n"
s1);
A.a大于bB.a小于bC.1D.输出语句有错
24.intk=10;
while(k=0)k=k-1;
则下面描述正确的是。
A.while循环执行10次B.循环是无限循环
C.循环体语句一次也不执行D.循环体语句执行一次
25.inta=1,b=2,c=2,t;
while(a<
b){t=a;
a=b;
b=t;
c--;
}
printf("
%d,%d,%d\n"
a,b,c);
运行结果为。
A.1,2,0B.2,1,0C.1,2,1D.2,1,1
26.intx=-1;
do
{x=x*x;
while(!
x);
下列说法正确的是。
A.是死循环B.循环执行两次
C.循环执行一次D.有语法错误
27.
以下能正确计算1*2*3*…*10的程序段是。
A.
do{i=1;
s=1;
B.do{i=1;
s=0;
s=s*i;
i++;
}s=s*i;
i++;
while(i<
=10);
C.i=1;
D.i=1;
do{s=s*i;
do{s=s*i;
}i++;
while(i<
while(i<
28.以下描述正确的是。
A.由于do-while循环中循环体语句只是一条可执行语句,所以循环体内不能使用复合语句
B.do-while循环由do开始,用while结束,在while(表达式)后面不能写分号
C.在do-while循环体中,一定要有能使while后面表达式的值变为零(“假”)的操作
D.do-while循环中,根据情况可以省略while
29.while和do-while循环的主要区别是。
A.do-while的循环体至少无条件执行一次
B.while的循环控制条件比do-while的循环控制条件严格
C.do-while允许从外部转到循环体内
D.do-while的循环体不能是复合语句
30.下面有关for循环的正确描述是。
A.for循环只能用于循环次数已经确定的情况
B.for循环是先执行循环体语句,后判断表达式
C.for循环中,不能用break语句跳出循环体
D.for循环的循环体语句中,可以包含多条语句,但必须用花括号括起来
31.对for(表达式1;
;
表达式3)可理解为。
A.for(表达式1;
0;
表达式3)
B.for(表达式1;
1;
表达式3)
C.for(表达式1;
表达式1;
D.or(表达式1;
表达式3;
32.在C编程语言中,以下正确的描述是。
A.continue语句的作用是结束整个循环的执行
B.只能在循环体内和switch语句体内使用break语句
C.在循坏体内使用break语句或continue语句的作用相同
D.从多层循环嵌套中退出,只能使用goto语句
33.下面程序段。
for(t=1;
t<
=100;
t++)
{scanf("
%d"
&
if(x<
0)continue;
%d\n"
t);
A.当x<
0时整个循环结束B.x>
=0时什么也不输出
C.cout永远也不执行D.最多允许输出100个非负整数
34.定义一个函数实现交换x和y的值,并将结果正确返回。
能够实现此功能的是。
A.swap(intx,inty){intt;
t=x;
x=y;
y=t;
}
B.swap(int*x,int*y){intt;
C.swap(int*x,int*y){intt;
t=*x;
*x=*y;
*y=t;
D.swap(int*x,int*y){int*t;
35.若有代数式3ae/bc,则不正确的C语言表达式是。
A.a/b/c*e*3B.3*a*e/b/c
C.3*a*e/b*cD.a*e/c/b*3
36.以下表达式值为3的是。
A.16-13%10B.2+3/2
C.14/3-2D.(2+6)/(12-9)
37.设有说明语句,intk=7,x=12;
则以下能使值为3的表达式是。
A.x%=(k%=5)B.x%=(k-k%5)
C.x%=k-k%5D.(x%=k)-(k%=5)
38.若有条件表达式(exp)?
A++:
b--,则以下表达式中能完全等价于表达式(exp)的是。
A.(exp==0)B.(exp!
=0)C.(exp==1)D.(exp!
=1)
39.设有以下语句:
typedefstructREC
{charc;
inta[4];
}REC1;
则下面叙述中正确的是。
A.可以用REC定义结构体变量
B.REC1是structREC类型的变量
C.REC是struct类型的变量
D.可以用REC1定义结构体变量
40.下列关于结构的语法错误的是
A.结构是由用户自定义的一种数据类型
B.结构中可设定若干个不同数据类型的成员
C.结构中成员的数据类型可以是另一个已定义的结构
D.在定义结构时,可以为成员设置默认值
41.以下关于结构体的叙述中,错误的是。
A.结构体是一种可由用户构造的数据类型
B.结构体中的成员可以具有不同的数据类型
C.结构体中的成员不可以与结构体变量同名
D.结构体中的成员可以是指向自身结构的指针类型
42.说明一个结构体变量时,系统分配给它的内存是。
A.各成员所需内存量的总和
B.结构中第一个成员所需内存量
C.成员中占内存量最大者所需的容量
D.结构中最后一个成员所需内存量
43.设有以下说明语句:
structstu
{inta;
floatb;
}stutype;
则下面的叙述不正确的是。
A.struct是结构体类型的关键字
B.structstu是用户定义的结构体类型名
C.stutype是用户定义的结构体类型名
D.a和b都是结构体成员名
44.若有如下定义
structdata
{intx,y;
}test1={10,20},test2;
则以下赋值语句中错误的是。
A.test2=test1;
B.test2.x=test1.x;
C.test2.x=test1.yD.test2={30,40};
45.以下对结构体变量stu1中成员age的非法引用是。
structstudent
{intage;
intnum;
}stu1,*p;
p=&
stu1;
A.stu1.ageB.student.ageC.p->
ageD.(*p).age
46.当说明一个共用体变量时,系统分配给它的内存是。
A.各成员所需内存量的总合
47.以下对C语言中共用体类型数据的叙述正确的是。
A.可以对共用体变量名直接赋值
B.一个共用体变量中可以同时存放其所有成员
C.一个共用体变量中不能同时存放其所有成员
D.共用体类型定义中不能出现结构体类型的成员
48.若有以下定义和语句:
uniondata
{inti;
charc;
floatf;
}a;
intn;
则以下语句正确的是。
A.a=5;
B.a={2,’a’,1.2}
C.printf(“%d\n”,a);
D.n=1;
49.设有以下说明,则下面不正确的叙述是。
union
{inti;
}un;
A.un所占的内存长度等于成员f的长度
B.un的地址和它的成员地址都是同一地址
C.un可以作为函数参数
D.不能对un赋值,但可以在定义un时对它初始化
50.C语言共用体类型变量在程序运行期间
A.所有成员一直驻留在内存中
B.只有一个成员驻留在内存中
C.部分成员驻留在内存中
D.没有成员驻留在内存中
51.使用typedef定义一个新类型的正确步骤是。
A.
(2)、(4)、
(1)、(3)B.
(1)、(3)、
(2)、(4)
C.
(2)、
(1)、(4)、(3)D.(4)、
(2)、(3)、
(1)
(1)把变量名换成新类型名
(2)按定义变量的方法写出定义体
(3)用新类型名定义变量
(4)在最前面加上关键则typedef
52.下面对typedef的叙述中不正确的是。
A.用typedef可以定义各种类型名,但不能用来定义变量
B.用typedef可以增加新类型
C.用typedef只是将已存在的类型用一个新的标识符来代表
D.使用typedef有利于程序的通用和移植
53.下面试图为double说明一个新类型名real的语句中,正确定是。
A.typedefrealdouble;
B.typedefdoublereal;
C.typedefreal=double;
D.typedefdouble=real;
54.下面能正确进行字符串赋值操作的是。
A.chars[5]={“ABCDE”};
B.chars[5]={‘A’,‘B’,‘C’,‘D’,‘E’};
C.char*s;
s=“ABCDE”;
D.char*s;
scanf(“%s”,s);
55.下面程序段的运行结果是。
char*s=”abcde”;
s+=2;
printf(“%d”,s);
A.cdeB.字符cC.字符c的地址D.无确定的输出结果
56.下面程序段的运行结果是。
charstr[]=”ABC”,*p=str;
printf(“%d\n”,*(p+3));
A.67B.0C.字符C的地址D.字符C
57.下面程序段的运行结果是。
chara[]=”language”,*p;
p=a;
while(*p!
=’u’){printf(“%c”,*p-32);
p++;
A.LANGUAGEB.languageC.LANGD.langUAGE
58.有如下说明语句,则以下不正确的叙述是。
chara[]=”Itismine”;
char*p=”Itismine”;
A.a+1表示的是字符t所在存储单元的地址
B.p指向另外的字符串时,字符串的长度不受限制
C.p变量中存放的地址值可以改变
D.a中只能存放10个字符
答案:
1.A2.C3.C4.D5.C6.B7.D8.A
9.B10.A11.B12.C13.D14.B15.C16.B
17.A18.D19.A20.C21.D22.B23.A
24.C25.D26.C27.C28.C29.A30.D31.B
32.B33.D34.C
35.C36.B37.D38.B39.D40.D41.C42.A
43.C44.D45.B46.C47.C48.B49.C50.B51.C
52.B53.B54.C55.C56.B57.C58.D
二、填空题
1.程序的三种基本的控制结构是:
、、。
2.C语言中的每条基本语句以
作为结束符,每条复合语句以
作为结束符。
3.关系表达式x+y>
5的相反表达式为
4.下面的程序段中循环体的执行次数是。
a=10;
b=0;
do{b+=2;
a-=2+b;
}while(a>
=0);
5.下面程序段的运行结果为。
x=2;
do{printf("
*"
x--;
}while(!
x==0);
6.已知inta[3][2]={3,2,1};
则表达式“a[0][0]/a[0][1]”的值是。
7.若用数组名作为函数调用时的实参,则实际上传递给形参的是。
8.如果一个函数无返回值,定义它时函数类型应是。
9.预处理命令以开头。
10.指针类型变量用于存储,在内存中它占有一个存储空间。
11.赋值语句在执行时先计算,再将该值转换成与一致的值,并将值赋给左部变量。
12.在程序中else总是与的if配对,而不管程序的书写格式如何。
13.在函数中使用语句返回值。
14.函数的形参在未被调用前分配空间,函数形参的要和实参相同。
15.函数调用一般分、,前者的特点是形参和实参各有独立的存储空间,形参的存储空间在函数被调用时才分配,形参内容的变化不影响实参,后者的特点是形参实参共用一个存储空间,形参内容的改变可以改变实参值。
16.在传值调用中,实际是把实参的传给形参。
17.inta[3]=3;
则a[2]=。
18.inta[3]={1,3,5,7};
则。
19.数组由和构成,其数组元素的数据类型是。
20.声明长度为10的float型数组a,且初始化为0的语句是:
21.指针是存放一个变量的的变量。
22.当数组名作形参时,相当于。
23.要访问数组元素可以采用、、。
24.定义一个指针p,它指向一个有6个整型元素的一维数组,定义语句为。
25.定义一个指针数组p,它有4个元素,每个指针指向一个整型数据,定义语句为。
26.指针可以指向字符串,在定义一个字符型指针时,可以给它初始化,目的是把字符串的放入指针变量。
27.指针可以指向函数,这时它所指的是函数的。
28.C语言的源程序必须通过和后,才能被计算机执行。
29.C语言源程序文件的后缀是;
经过编译后,生成文件的后缀是;
经过连接后,生成文件的后缀是。
30.在C语言中,表示逻辑“真”值用。
31.设y为int型变量,请写出描述“y是奇数”的表达式。
32.C语言提供的3种逻辑运算符是、和。
33.若x、y、z均为int型变量,则描述“x或y中有一个小于z”的表达式是。
34.设a、b、c均为int型变量且a=7.5,b=2,c=3.6,则表达式a>
b&
c>
a||a<
!
c>
b的值是。
35.设a、b、c均为int型变量且a=6,b=4,c=2,则表达式!
(a-b)+c-1&
b+c/2的值是。
36.设a、b均为int型变量且a=2,b=4,则表达式!
(x=a)||(y=b)&
0的值是。
37.设a、b、c均为int型变量且a=1,b=4,c=3,则表达式!
(a<
b)||!
c&
1的值是。
38.若有条件“2<
x<
3或x<
-10”,其对应的C语言表达式是。
1.顺序结构选择结构循环结构
2.;
3.x+y<
=5
4.3
5.**
6.1
7.数组首地址
8.内置函数
9.#
10.所指变量的地址
11.表达式的值左部变量类型
12.它前面最近且未配对
13.return
14.不类型及数量
15.传值调用传址调用
16.值
17.0
18.会出错
19.数组名下标相同的
20.floata[10]={0};
21.地址
22.指针
23.下标法地址法指针法
24.int(*p)[6]
25.int*p[4]
26.首地址
27.入口地址
28.编译连接
29.cobjexe
30.非0数字
31.(y%2)==1
32.&
||!
33.x<
z||y<
z
34.0
35.1
36.0
37.0
38.x<
3&
x>
2||x<
-10
三、填空完成下面的程序
1.以下程序的功能是:
输出x,y,z三个数中的最大者。
请填空。
#include<
stdio.h>
intmain()
{intx=4,y=6,z=7;
intu,v;
if(x>
y)u=x;
elseu=y;
if(u>
z)v=u;
elsev=z;
printf(“v=%d”,v);
return0;
2.以下程序的功能是:
输入3个整数,按从大到小的顺序进行输出。
{intx,y,z,c;
scanf(“%d%d%d”,&
x,&
y,&
z);
if(y<
z)
{c=y;
y=z;
z=c;
if(x<
{c=x;
x=z;
y)
x=y;
y=c;
printf(“%d,%d,%d”,x,y,z);
3.以下程序的功能是:
输入一个字符,如果它是一个大写字母,则把它变成小写字母;
如果它是一个小写字母,则把它变成大写字母;
其他字符不变。
{charch;
scanf(“%c”,&
ch);
if(ch>
=’A’&
ch<
=’Z’)ch=ch+32;
elseif(ch>
=’a’&
=’z’)ch=ch-32;
printf(“%c”,ch);
4.以下程序的功能是:
根据输入的三角形的三条边,判断是否能组成三角形,若可以则输出它的面积和三角形的类型。
#include<
math.h>
{floata,b,c;
floats,area;
scanf(“%f%f%f”,&
a,&
b,&
c);
if(a+b>
b+c>
a&
a+c>
b)
{s=(a+b+c)/2;
area=sqrt(s*(s-a)*(s-b)*(s-c))