C语言考试试题基础版.docx
《C语言考试试题基础版.docx》由会员分享,可在线阅读,更多相关《C语言考试试题基础版.docx(25页珍藏版)》请在冰豆网上搜索。
C语言考试试题基础版
一、选择题
1.在每个C程序中都必需包含有这样一个函数,该函数的函数名为 。
A.main B.MAIN C.name D.function
2.在以下关于C语言的注释的表达中,不正确的选项是。
A.注释可用"/*"、"*/"形式表示,也可用"//"形式表示
B.编译器在编译一个程序时,将跳过注释,不对其进展处理
C.编译器在编译一个程序时,可发觉注释中的单词拼法错误
D.程序中注释的多少不会影响所生成的可执行文件的长度
3.以下表达不正确的选项是。
A.在C程序中,严格区分大小写字母
B.一个C源程序有且仅有一个main函数
C.在C程序中,注释只能位于一条语句的后面
D.一个C程序总是从main函数起先执行
4.以下合法的标识符为
A.abde+B.#KDJFC.67KDJD.DK3_
5.关于字符串和字符的关系正确的选项是
A.“A”与’A’是一样的
B.字符串是常量,字符是变量
C.“A”与’A’是不同的
D.“A”与“A”是一样的
6.
if(x>y)
{z=x;s=z*z;}
else
{z=y;s=1/(z*z);}
if(x>y)
z=x;s=z*z;
else
z=y;s=1/(z*z);
下面关于语句的说法正确的选项是
A.下面这两段程序的执行效果是一样的
B.空语句是只有一个分号的语句,它其实什么也不干
C.语句的构成不必须须要分号
D.语句的书写对程序的运行不起作用,因此可以随意写都可以
7.以下各标识符中,合法的用户标识符组为。
A.PAd,P#d,b-b,abc,_0123,ssiped
B.cin,a10,CPP,float,del_word,signed
C.void,max,hiy,,list,*jer
D.a,temp,_isw,INT,keep,wind
8.字符串“\”EOF=-\61\””的长度是。
A.8 B.9 C.12D.非法字符串
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
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);while(i<=10);
C.i=1;s=1;D.i=1;s=0;
do{s=s*i;do{s=s*i;
i++;}i++;}
while(i<=10);while(i<=10);
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;表达式3)
D.or(表达式1;表达式3;表达式3)
32.在C编程语言中,以下正确的描述是。
A.continue语句的作用是完毕整个循环的执行
B.只能在循环体内和switch语句体内运用break语句
C.在循坏体内运用break语句或continue语句的作用一样
D.从多层循环嵌套中退出,只能运用goto语句
33.下面程序段。
for(t=1;t<=100;t++)
{scanf("%d",&x);
if(x<0)continue;
printf("%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;t=x;x=y;y=t;}
C.swap(int*x,int*y){intt;t=*x;*x=*y;*y=t;}
D.swap(int*x,int*y){int*t;t=x;x=y;y=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.各成员所需内存量的总合
B.构造中第一个成员所需内存量
C.成员中占内存量最大者所需的容量
D.构造中最终一个成员所需内存量
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;charc;floatf;}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
c&&1的值是。
38.假设有条件“2
答案:
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.x34.0
35.1
36.0
37.0
38.x<3&&x>2||x<-10
三、填空完成下面的程序
1.以下程序的功能是:
输出x,y,z三个数中的最大者。
请填空。
#include
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个整数,按从大到小的依次进展输出。
请填空。
#include
intmain()
{intx,y,z,c;
scanf(“%d%d%d”,&x,&y,&z);
if(y{c=y;y=z;z=c;}
if(x{c=x;x=z;z=c;}
if(x{c=x;x=y;y=c;}
printf(“%d,%d,%d”,x,y,z);
return0;
}
3.以下程序的功能是:
输入一个字符,假如它是一个大写字母,那么把它变成小写字母;假如它是一个小写字母,那么把它变成大写字母;其他字符不变。
请填空。
#include
intmain()
{charch;
scanf(“%c”,&ch);
if(ch>=’A’&&ch<=’Z’)ch=ch+32;
elseif(ch>=’a’&&ch<=’z’)ch=ch-32;
printf(“%c”,ch);
return0;
}
4.以下程序的功能是:
依据输入的三角形的三条边,判定是否能组成三角形,假设可以那么输出它的面积和三角形的类型。
请填空。
#include
#include
intmain()
{floata,b,c;
floats,area;
scanf(“%f%f%f”,&a,&b,&c);
if(a+b>c&&b+c>a&&a+c>b)
{s=(a+b+c)/2;
area=sqrt(s*(s-a)*(s-b)*(s