C语言考试试题基础版文档格式.docx
《C语言考试试题基础版文档格式.docx》由会员分享,可在线阅读,更多相关《C语言考试试题基础版文档格式.docx(25页珍藏版)》请在冰豆网上搜索。
9.数学式
在C程序中对应的不正确的表达式为。
A.sqrt(sin(x)>
0?
sin(x):
-sin(x))B.sqrt(fabs(sinx))
C.sqrt(sqrt(sinx*sinx))D.fabs(sqrt(sin(x)))
10.以下是C语言的有效标识符?
A._No1B.No.1C.12345D.int
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