C语言试题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C语言习题精选
第一章、程序设计基本概念
一.选择题
1.C语言规定,必须用(C)作为主函数
(A)function (B)include (C)main
(D)stdio
2.一个C程序可以包含任意多个不同名的函数,
但有且仅有一个(B),一个C程序总是从(B)
开始执行。
(A)过程(B)主函数(C)函数
(D)include
3.! C源程序是由(A)构成的
(A)函数(B)函数和过程(C)超文本过程
(D)子程序
4.(A)是C程序的基本构成单位
(A)函数(B)函数和过程(C)超文本过程
(D)子程序
5.! 下列说法正确的是(C)
(A)一个函数的函数体必须要有变量定义
和执行部分,二者缺一不可
(B)一个函数的函数体必须要有执行部
分,可以没有变量定义
(C)一个函数的函数体可以没有变量定义
和执行部分,函数可以是空函数
(D)以上都不对
6.下列说法正确的是(D)
(A)main函数必须放在C程序的开头
(B)main函数必须放在C程序的最后
(C)main函数可以放在C程序的中间部
分,即在一些函数之前在另一个函数
之后,但在执行C程序时是从程序开
头执行的
(D)main函数可以放在C程序的中间部
分,即在一些函数之前在另一些函数
之后,但在执行C程序时是从main
函数开始的
7.下列说法正确的是(C)
(A)在执行C程序时不是从main函数开
始的
(B)C程序书写格式严格限制,一行内必
须写一个语句
(C)C程序书写格式自由,一个语句可以
分写在多行上
(D)C程序书写格式严格限制,一行内必
须写一个语句,并要有行号
8.在C语言中,每个语句和数据定义是用(C)
结束
(A)句号(B)逗号(C)分号(D)括号
9.下列字符串是标识符的是(A)(注:以字母或
下划线开头)
(A)_HJ (B)9_student (C)long
(D)LINE 1
10.以下说法正确的是(C)
(A)C语言程序总是从第一个定义的函数
开始执行
(B)在C语言程序中,要调用的函数必须
在main()函数中定义
(C)C语言程序总是从main()函数开始执
行
(D)C语言程序中的main()函数必须放在
程序的开始部分
11.(B)不是C语言提供的合法关键字()
(A)switch (B)print (C)case
(D)default
12.C语言提供的合法关键字是(A)
(A)break (B)print (C)funition
(D)end
13.C语言提供的合法关键字是(A)
(A)continue (B)procedure (C)begin
(D)append
二.填空题
1.一个C源程序至少包含一个(主函数),即
(main())
2.!一个函数由两部分组成,它们是(函数的说
明部分)和(函数体)
3.!函数体一般包括(变量的定义部分)和(执
行部分)
4.!函数体的范围是(最外层的一对大括弧内的
部分)
5.!C语言是通过(输入和输出函数)来进行输
入和输出的
6.!在C语言中,凡在一个标识符后面紧跟着一
对圆括弧,就表明它是一个(函数)
7.C语言的关键字都用(小写){大写或小字}
8.!主函数名后面的一对圆括号中间可以为空,
但一对圆括号不能(省)
第二章、 C程序设计的初步知识
一.选择题
1.C语言中不能用来表示整常数的进制是(D)
(A)十进制(B)十六进制(C)八进制(D)二进制
2.在C语言中,反斜杠字符是(D)(A)\n (B)\t (C)\v (D)\\
3.在ASCII代码表中可以看到每一个小写字母比
它相应的大写字母的ASCII码(A)
(A)大32 (B)大64 (C)小32 (D)小1
4.设d为字符变量,下列表达式不正确的是(C)
(A)d=97 (B)d=‟a‟ (C)d=”a”
(D)d=‟g‟
5.10+‟a‟+1.5-567.345/‟b‟的结果是(B)
(A)long (B)double (C)int (D)unsigned float
6.!在C语言中,运算对象必须是整型数的运算
符是(A)
(A)% (B)/ (C)%和/ (D)**
7.为表示关系x>=y>=z,应使用C语言表达式(A)
(A)(y<=x)&&(y>=z) (B)(x>=y)AND(y>=z)
(C)(x>=y>=z) (D)(x>=y)&(y>=z)
8.若欲表示在if后a不等于0的关系,则能正确
表示这一关系的表达式为(D)
(A)a<>0 (B)!a (C)a=0 (D)a!=0
9.?下列常数中,合法的C常量是(A)
(A)”x-y” (B)‟105‟ (C)‟Be‟ (D)7ff
10.?下列常数中,合法的C常量是(A)
(A)-0. (B)‟105‟ (C) …AB‟(D)3+5
11.下列常数中,合法的C常量是(A)
(A)‟\n‟ (B)e-310 (C)‟DEF‟ (D)‟1234‟
12.下列常数中,不合法的C常量是(B)
(A)-0x2a1 (B)lg3 (C)‟[… (D)”CHINA”
13.下列常数中,不合法的C常量是(B)
(A)-0x3b1 (B)123e+2.3 (C)‟}‟ (D)6e+7
14.?下列符号中,可以作为变量名的是(C)
(A)+a (B)12345e (C)a3B (D)5e+0
15.写出下面程序的输出结果(A)
main()
{int x,y,z;
x=y=1;
z=x++-1;
printf(“%d,%d\t”,x,z);
z+=-x+++(++y||++z);
printf(“%d,%d”,x,z);}
(A)2,0 3,-1 (B)2,1 3,0 (C)2,0 2,1 (D)2,1
0 ,1
16.写出下面程序的输出结果(D)
main()
{int x=40,y=4,z=4;
x = y = =z;
printf(“%d”,x);
x = x = = (y-z);
printf(“%d”,x);}
(A)4 0 (B)4 1 (C)1 1 (D)1 0
17.写出下面程序的输出结果(A)
main()
{int I,j;
I=16; j=(I++)+I;printf(“%d”,j);
I=15;printf(“%d %d”,++I,I);}
(A)32 16 15 (B)33 15 15 (C)34 15 16
(D)34 16 15
18.若已定义x和y为double类型,则表达式:
x=1,y=x+3/2的值为(C)
(A)1 (B)2 (C)2.0 (D)2.5
19.?下列程序的执行结果是(B)
#define sum 10+20
main()
{ int b=0,c=0;
b=5;
c=sum*b;
printf(“%d”,c);
}
(A)100 (B)110 (C)70 (D)150
20.表达式(double)(20/3)的值为(B)
(A)6 (B)6.0 (C)2 (D)3
二.填空题
1.如果int I=3;则k=(I++)+(I++)+(I++),则k =(9),
I=(6);
2.?如果int I=3;则k=(I++)+(++I)+(I++),则
k=(12), I=(6);
3.?如果int I=3;则k=(++I)+(++I)+(I++),则
k=(15),I=(6);
4./如果int I=3;则k=(++I)+(++I)+(++I),则
k=(18),I=(6);
5.已知在ASCII字符集中,字母A的序号为65,
下面程序的输出结果为(K,5)
main()
{char c=‟A‟; int I=10;
c = c+10;
I = c%I;
Printf(“%c,%d\n”,c,I); }
6.!C语言的数据类型有四大类,其分别为(基
本数据类型),(构造类型),(指针),(空类型)。
7.!C语言的数据类型中构造类型包括三种,它
们是(数组),(结构体),(共用体)。
8.!C语言基本数据类型包括(整型),(实型),
(字符型),(枚举类型)。
9.!在C语言中,常量有不同的类型,包括(整
型),(实型),(字符)和(字符串)。
10.!符号常量是指(用一个标识符代表的一个常
量)。
11.整型常量和实型常量也称为(数值型常量),它
们有正负值之分。
12.C语言中,习惯上符号常量名用(大写),变量
用(小写)。
{大写或小写}
13.C语言在定义变量的同时说明变量的(数据类
型),系统在编译时就能根据变量定义及其(数
据类型)为它分配相应大小的存储空间。
14.在C语言中,用来标识变量名,符号常量名,
函数名,数组名,类型名,文件名的有效字符
序列称为(标识符)
15.整型变量可分为(基本型),(短整型),(长整
型),(无符号型)四种,分别用(int),(short),
(long),(unsigned)表示。
16.在一个整常量后面加一个字母(L)或(l),则
认为是long int 型常量。
17.在C语言中,实数有两种表示形式,即(十进
制形式)和(指数形式)。
18.?下面的程序
main()
{printf(“_ _ _ ab _ c\t _de\rfg\n”);
printf(“h\ti\b\b\j _ _ _k”);}
运行结果是()
19.在C语言中,系统在每一个字符串的结尾自动
加一个”字符串结束标志符”即()以便系统据此判断字符串是否结束。
20.?表达式10+‟a‟+1.5-0.5*‟B‟的结果是()
21.表达式10+‟a‟+1.5-567.345/‟b‟的结果是
(double)型数据
22.!在TURBO C中,单精度实数的数值范围约
在()之间。
23.下面的程序:
main()
{float x;int I;
x=3.6; I=(int)x;
printf(“x=%f,I=%d”,x,I);}
运行结果为(3.600000,,3)
24.!在C语言中,表达式的类型有(赋值),(算
术),(逻辑),(关系),(逗号),(条件)。
25.分析下面的程序:
main()
{int a,b,c;
a=b=c=1;
a+=b;
b+=c;
c+=a;
printf(“(1)%d\n”,a>b?a:b);
printf(“(2)%d\n”,a>c?a--:c++);
(a>=b>=c)?printf(“AA”):printf(“CC”);
printf(“\n a= %d,b= %d,c= %d\n”,a,b,c);}
运行结果为()
26.用C语言描述下列命题
(1)a小于b或小于c
(2)a和b都大于c
(3)a或b中有一个小于c
(4)a是奇数a%2==1
27.若x=3,y=2,z=1,求下列表达式的值:
(1)x<y?y:x
(2)x<y?x++:y++
(3)z+=x<y?x++:y++(注:<优先级高
于+=即左边等于z+=(x<y))28.!sizeof用于计算出各个数据类型使用多少内
存空间,若有语句:I=sizeof(int);j= sizeof(char),则I=(2);j=(1)
29.!若I= sizeof(float);j= sizeof(double),则
I=(4),j=(8).
30.在C语言中,可以利用(强制类型转换),将
一个表达式的值转换成指定的类型。
第三章、顺序结构(基本语句)
一.选择题
1.C语言中调用printf函数进行输出时需要注意,在
格式控制串中,格式说明与输出项的个数必须相同。
如果格式说明的个数小于输出项的个数,多余的输出项将();如果格式说明的个数多于输出项的个数,则对于多余的格式将输出不定值(或0)。
(A)不予输出(B)输出空格(C)照样输出(D)输出不定值或0
2.在scanf函数的格式控制中,格式说明的类型与输
入项的类型应该一一对应匹配。
如果类型不匹配,系统将()。
(A)不予接收(B)并不给出出错信息,但不可能得到正确数据(C)能接收到正确输入(D)给出出错信息,不予接收输入
3.以下程序的输出结果是()
main()
{
int I=011,j=11,k=0x11;
printf(“%d,%d,%d\n”,I,j,k);
}
(A)9,11,17 (B)9,11,11 (C)11,11,11 (D)11,11,16
4.以下程序的输出结果是()
#include<stdio.h>
main()
{printf(“%d\n”,NULL);}
(A)不确定的值(因变量无定义)(B)0 (C)-1 (D)1
5.以下程序的输出结果是()
main()
{char c1=‟6‟, c2=‟0‟;
printf(“%c,%c,%d,%d\n”,c1,c2,c1-c2,c1+c2);}
(A)输出出错信息(B)6,0,6,102 (C)6,0,7,6 (D)6,0,5,7 6.有如下定义:int x= 10, y= 5, z;则语句
printf(“%d\n”,z=(x+=y,x/y));的输出结果是()(A)1 (B)0 (C)4 (D)3
7.以下程序的输出结果是()
main()
{int a = -1 ,b = 4, k;
k = ( ++a <= 0) && !(b -- <= 0);
printf(“%d %d %d\n”,k,a,b);}
(A)1 0 4 (B)0 0 4 (C)1 0 3 (D)0 0 3
8.若有定义:int x,y; char a,b,c;并有以下输入数据(此
处,<cr>代表换行符)
1 2<cr>
A B C<cr>
则能给x赋整数1,给y赋整数2,给a赋字符A,给b 赋字符B,给c赋字符C的正确程序段是:
(A)scanf(“x=%dy=%d”,&x,&y);a=getchar();b=getchar();c =getchar();
(B)scanf(“%dy%d”,&x,&y);a=getchar();b=getchar();c=ge tchar();
(C)scanf(“%d%d%c%c%c%c%c%c”,&x,&y,&a,&a,&b, &b,&c,&c);
(D)scanf(“%d%d%c%c%c”,&x,&y,&a,&b,&c);
9.若已定义int a = 25, b = 14, c = 19 ;以下三项运算符
(?:)所构成的语句的执行结果是()
a++ <= 25 && b-- <= 2 && c++ ? printf(“***a=%d,b=%d,c=%d\n”,a,b,c) : printf(“###a=%d,b=%d,c=%d\n”,a,b,c)
(A)(***a=25,b=14,c=19)(B)(***a=26,b=13,c=19)
(C)(###a=25,b=14,c=19)
(D)(###a=26,b=13,c=19)
10.以下C程序,正确的运行结果是()(注_代表空格)
main()
{long y = -34567;
printf("y=%-8ld\n",y);
printf("y=%-08ld\n",y);
printf("y=%08ld\n",y);
printf("y=%+8ld\n",y);}
(A)y = _ _ -34567 (B)y = - 34567(C)y = - 34567(D)y = _ _ -34567
y = - _ _ 34567 y = - 34567 y = -34567 y = - 0034567
y = - 0034567 y = - 0034567 y = -0034567 y = 00034567
y = -34567 y = + _ -34567 y = _ _ -34567 y = + 34567
二.填空题
1.C语言中的语句可分为五类,即()、()、()、()、
()。
2.由一次函数调用加一个分号构成一个()语句。
3.printf是C语言提供的标准输出函数,它的作用是
()。
4.printf函数的”格式控制”包括两部分,它们是()
和()。
5.如果想输出字符”%”,则应该在”格式控制”字符串
中用()表示。
6.符号‟&‟是()运算符,&a是指()。
7.scanf函数的”格式控制”后面应当是(),而不是()。
8.C语言中的空语句就是()。
9.返回语句的功能是从()返回()。
10.复合语句是由一对()括起来的若干语句组成的。
11.下列程序的输出结果是()
#include<stdio.h>
main()
{ch ar b[]=”ABCDEFG”;
char *chp=&b[7];
while(-- chp>&b[0])
putchar(*chp);
putchar(…\n‟);}
12.下列程序的输出结果是()
main()
{int x =2,y,z;
x* = 3+2; printf(“%d\n”,x);
x* = y = z = 4; printf(“%d\n”,x);
x = y = z ; printf(“%d\n”,x);
x = (y = z); printf(“%d\n”,x);}
13.下列程序的输出结果是()
main()
{printf(“%d”,1<4&&4<7):
printf(“%d”,1<4&&7<4);
printf(“%d”,(2<5));
printf(“%d”,!(1<3)||(2<5));
printf(“%d”,!(4<=6)&&(3<=7));}
14.下列程序的输出结果是()
main()
{int x,y;
x=16; y=(x++)+x; printf(“%d\n”,y);
x=15; printf(“%d,%d\n”,++x,x);
x=20;y=x-- + x; printf(“%d\n”,y);
x=13;printf(“%d,%d”,x++,x);}
15.阅读程序
main()
{ char str1[]="people and computer",str2[10];
char *p1=str1,*p2=str2;
scanf("%s",p2);
printf("%s",p2);
printf("%s\n",p1);}
运行上面的程序,输入字符串PEOPLE AND COMPUTER ,则程序的输出结果是()。
三.编程题
1.从键盘输入一个大写字母,要求改用小写字母
输出;
2.编写程序,判断某一年是否闰年;
3.编写求方程ax2 + bx + c的解x 的程序;
第四章、选择结构
1.下列运算符中优先级最高的是()。
(A)> (B)+ (C)&& (D)!=
2.逻辑运算符运算对象的数据类型()。
(A)只能是0和1 (B)只能是.T.或.F. (C)只能是整型或字符型(D)任何类型的数据
3.能正确表示x的取值范围在[0,100]和[-10,-5]内的表
达式是()。
(A)(X<=-10)||(x>=-5)&&(x<=0)||(x>=100) (B)(x>=-10)&&(x<=-5)||(x>=0)&&(x<=100)
(C)(x>=-10)&&(x<=-5)&&(x>=0)&&(x<=100)(D)(x<=-10)| |(x>=-5)&&(x<=0)||(x>=100)
4.以下程序的运行结果是()。
Main()
{int c,x,y;
x=1; y=1; c=0;
c=x++ || y++ ;
printf(“\n%d %d %d\n”,x,y,c);}
(A)1 1 0 (B) 2 1 1 (C)2 2 1 (D) 0 0 1
5.以下程序的运行结果是()。
Main()
{int c,x,y;
x=0; y=0; c=0;
c=x++ && y++;
printf(“\n%d %d %d\n”,x,y,c);}
(A)1 0 0 (B)1 1 0 (C)0 1 1 (D)0 0 1
6.两次运行下面的程序,如果从键盘上分别输入6和
4,则输出结果是()。
Main()
{int x;
scanf(“%d”,&x);
if(x++>5) printf(“%d”,x);
else printf(“%d\n”,x--);}
(A)7和5 (B)6和3 (C)7和4 (D)6和4 7.写出下面程序的运行结果()。
Main()
{ int x=1, y=1 ,z=0;
if(z<0)
if(y>0) x=3;
else x=5;
printf(“%d\t”,x);
if(z=y<0) x=3;
else if(y= = 0) x=5;
else x=7;
printf(“%d\t”,x);
printf(“%d\t”,z);}
(A)1 7 0 (B)3 7 0 (C)5 5 0 (D)1 5 1
8.写出下面程序的运行结果()。
Main()
{int x,y=1,z=0;
if(y!=0) x=5;
printf(“x=%d\t”,x); if(y = = 0) x=3; else x=5;
printf(“x=%d\t\n”,x);
x=1;
if(z<0)
if(y>0) x=3; else x=5; printf(“x=%d\t\n”,x);
if(z=y<0) x=3;
else if(y = = 0) x=5;
else x=7;
printf(“x = %d\t”,x);
printf(“z = %d\t\n”,z);
if(x=z=y) x=3;
printf(“x=%d\t”,x);
printf(“z=%d\t\n”,z);}
(A)x=5 x=5 (B)x=5 x=5 (C)x=5 x=5 (D)x=5 x=5
x=1 x=1 x=5 x=1
x=7 z=0 x=5 z=0 x=7 z=0 x=7 z=0
x=3 z=1 x=3 z=0 x=3 z=1 x=3 z=0
9.若有以下函数关系
x < 0时y = 2x
x > 0时y=x
x = 0时y=x+1
下面程序段能正确表示以上关系的是()。
(A)y = 2x; (B)y = 2x; (C)if(x >= 0) (D)y= x+1;
if(x!=0) if(x<=0) if(x>0) y=x; if(x<=0)
if(x>0) y=x; if(x= =0) y=x+1; else y=x+1; if(x<0) y=2x;
else y=x+1; else y=x; else y=2x; else y=x;
10.若有以下变量定义:
float x;int a,b;
则正确的switch语句是()。
(A)switch(x) (B)switch(x) (C)switch(a+b) (D)switch(a+b)
{case 1.0:printf(“ok”); {case 1,2:printf(“ok”); {case 1:printf(“ok”); {case 1:printf(“ok”);
case 2.0:printf(“this”); case .3:printf(“this”); case 2*a:printf(“this”); case 1+2:printf(“this”);
} } }
}
二.填空题
1.以下两条if语句合并成一条if语句为()。
if(a <= b) x=1;
else y=2;
if(a>b) printf(“****y=%d\n”,y);
else printf(“####x=%d\n”,x);
2.以下程序的功能是计算一元二次方程ax2+bx+c=0的根,补足程序中空缺的语句。
#include<math.h> main()
{float a,b,c,_abs,_derta,_doublea,part1,part2;
printf(“enter a ,b,c:”);
scanf(“%f%f%f”,&a,&b,&c);
if( )
if( ) printf(“no answer due to input error\n”);
else printf(“the single root is %f\n”,-c/b);
else
{ _derta = b*b – 4*a*c;
_doublea = 2*a;
part1 = -b/(2*a);
_abs = abs(_derta);
part2 = sqrt(_abs)/_doublea;
if( )
printf(“complex root\n real part=%f image part = %f\n”,part1,part2);
else
printf(“real roots\n root1 = %f root2 = %f\n”,part1+part2,part1- part2);
}
}
3.以下程序段的运行结果是()。
int x=1 ,y=0;
switch(x)
{case 1:
switch(y)
{
case 0: printf(“x=1 y=0\n”);break;
case 1:printf(“x=1\n”);break;
}
case …2‟:printf(“x=2\n”);
}
4.根据以下if语句写出与其功能相同的switch语句。
(x的值在0-100之间)
if语句:
if(x<60) m=1;
else if(x<70) m=2;
else if(x<80) m=3;
else if(x<90) m=4;
else if(x<100) m=5;
switch语句:
switch( )
{
( ) m=1:break;
case 6:m=2;break;
case 7:m=3;break;
case 8:m=4;break;
( ) m=5;
}
三.编程题
1.编写一程序,要求由键盘输入三个数,计算以
这三个数为边长的三角形面积。
2.输入圆的半径r和一个整型数k,当k = 1时,
计算圆的面积;当k= 2时,计算圆的周长;
当k = 3时,既要求出圆的面积也要求出圆的
周长。
编程实现以上功能。
第五章、循环结构
一.选择题 1.在do-while循环中,循环由do开始,用while结束;
必须注意的是:在while表达式后面的()不能丢,它表示do-while循环的结束。
(A)0 (B)1 (C);(D),
2.for语句中的表达式可以部分或全部省略,但两个()不可省略。
但当三个表达式均省略后,因缺少判断条件,循环会无限制地执行下去,形成死循环。
(A)0 (B)1 (C);(D),
3.程序段如下:
int k=1;
while(! k= = 0){k = k+1; printf(“%d\n”,k);}
则以下说法中正确的是()
(A)while循环执行2次(B)无限循环(C)循环体语句一次也不执行(D)执行一次
4.程序段如下:
int k=0;
while(k ++ <= 2); printf(“last = %d\n”,k);
则正确的执行结果是last = ( )
(A)2 (B)3 (C)4 (D)无结果
5.执行下面的程序后,a 的值为()
main()
{ int a , b;
for( a=1 , b=1 ; a<=100; a++)
{ if(b>=20) break;
if(b%3 = = 1)
{ b+=3;
continue;
}
b-=5;
}
}
(A)7 (B)8 (C)9 (D)10
6.分析下列程序
main()
{ int n[3], I, j,k;
for(I=0; I<3;I++)
n[I]=0;
k=2;
for(I=0;I<k;I++)
for(j=0;j<k;j++)
n[j]=n[I]+1;
printf(“%d\n”,n[1]);
}
(A)2 (B)1 (C)0 (D)3 7.下面程序的输出结果是()
main()
{ int n = 0;
while(n++ <=1)
printf(“%d\t”,n);
printf(“%d\n”,n);
}
(A)1 2 3 (B)0 1 2 (C)1 1 2 (D)1 2 2
8.当输入为”quert?”时,下面程序的执行结果是()main()
{ char c;
c=getchar();
while((c=getchar())!=‟?‟) putchar(++c);
}
(A)Quert (B)vfsu (C)quert? (D)rvfsu?
9.当输入为”quert?”时,下面程序的执行结果是()main()
{while(putchar(getchar())!=‟?‟);}
(A)quert (B)Rvfsu (C)quert? (D)rvfsu?
10.当输入为”quert?”时,下面程序的执行结果是()main()
{char c;
c=getchar();
while(c!=‟?‟)
{
putchar( c );
c=getchar();
}
}
(A)quert (B)Rvfsu (C)quert? (D)rvfsu? 二.填空题
1.将for(表达式1;表达式2;表达式3)语句改写
为等价的while语句为()
2.break语句的功能是( )
3.break语句只能用于()语句和()语句
4.continue语句的作用是(),即跳过循环体中
下面尚未执行的语句,接着进行下一次是否执
行循环的判定。
三.编程题
1.求100-200间的全部素数
2.编一程序,将2000年到3000年中所有的闰年
年份输出并统计出闰年的总年数,要求每10
个闰年放在一行输出。
第六章、数组
一.选择题
1.若有语句int a[8];则下述对a 的描述正确的是()。
(A)定义了一个名称为a的一维整型数组,共有8个元素
(B)定义了一个数组a,数组a共有9个元素
(C)说明数组a的第8个元素为整型变量
(D)以上可选答案都不对
2.在C语言中,引用数组元素时,其数组下标的数据类型允许是()。
(A)整型常量
(B)整型表达式
(C)整型常量或整型表达式
(D)任何类型的表达式
3.下述对C语言字符数组的描述正确的是()。
(A)任何一维数组的名称都是该数组存储单元的开始地址,且其每个元素按照顺序连续占用存储空间
(B)一维数组的元素在引用时其下标大小没有限制(C)任何一个一维数组的元素,可以根据内存的情况按照其先后顺序以连续或非连续的方式占用存储空间(D)一维数组的第一个元素是其下标为1的元素
4.下述对C语言字符数组的描述中正确的是()。
(A)任何一个一维数组的元素在引用时,其下标可以是整型、实型或字符型常量
(B)一维数组的元素实质上就是一个变量,代表内存中的一个存储单元
(C)如果要引用数组中的每一个元素,则直接使用该数组名称即可
(D)以上都不对
5.以下对一维整型数组a的正确说明是()。
(A)int a(10); (B)int n=10,a[n]; (C) int n;
(D) #define SIZE 10
scanf(“%d”,&n); int a[SIZE];
int a[n];
6.以下能对一维数组a进行正确初始化的语句是()(A)int a[10]=(0,0,0,0,0);(B)int a[10]={};(C)int a[]={0};(D)int a[10]=(10*1);
7.若有说明:int a[3][4];则对a数组元素的正确引用是()
(A)a[2][4] (B)a[1,3] (C)a[1+1][0] (D)a(2)(1) 8.以下能对二维数组a进行正确初始化的语句是()(A)int a[2][]={{1,0,1},{5,2,3}};(B)int a[][3]={{1,2,3},{4,5,6}};
(C)int a[2][4]={{1,2,3},{4,5},{6}};(D)int a[][3]={{1,0,1}{},{1,1}};
9.若有说明:int a[3][4]={0};则下面正确的叙述是()(A)只有元素a[0][0]可得到初值0(B)此说明语句不正确
(C)数组a中各元素都可得到初值,但其值不一定为0
(D)数组a中每个元素均可得到初值0
10.以下各组选项中,均能正确定义二维实型数组a的选项是()
(A)float a[3][4]; float a[][4]; float a[3][]={{1},{0}}; (B)float a(3,4); float a[3][4]; float a[][]={{0};{0}}; (C)float a[3][4]; static float a[][4]={{0},{0}};
(D)float a[3][4]; float a[3][];
11.若二维数组a有m列,则计算任一元素a[i][j]在数组中位置的公式为()
(假设a[0][0]位于数组的第一个位置上。
)
(A)i*m+j(B)j*m+i(C)i*m+j-1(D)i*m+j+1 12.对以下说明语句的正确理解是()
int a[10] = {6,7,8,9,10};
(A)将5个初值依次赋给a[1]至a[5] (B)将5个初值依次赋给a[0]至a[4]
(C)将5个初值依次赋给a[6]至a[10](D)因为数组长度与初值的个数不相同,语句有错
13.若有说明:int a[][3]={1,2,3,4,5,6,7};则a数组第一维的大小是()
(A)2 (B)3 (C)4 (D)不确定
14.定义如下变量和数组:
int I;
int x[3][3]={1,2,3,4,5,6,7,8,9};
则下面语句的输出结果是()
for(I=0;I<3;I++)
printf(“%d”,x[I][2-I]);
(A)1 5 9(B)1 4 7(C)3 5 7(D)3 6 9
15下面程序的运行结果是()
main()
{int a[6][6],I,j;
for(I=1;I<6;I++)
for(j=1;j<6;j++)
a[I]][j]=(I/j) * (j/I)
for(I=1;I<6;I++)
{for(j=1;j<6;j++)
printf(“%2d”,a[I][j]);
printf(“\n”);}
}
(A)1 1 1 1 1 (B)0 0 0 0 1 (C)1 0 0 0 0 (D)1 0 0 0 1
1 1 1 1 1 0 0 0 1 0 0 1 0 0 0 0 1 0 1 0
1 1 1 1 1 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0
1 1 1 1 1 0 1 0 0 0 0 0 0 1 0 0 1 0 1 0
1 1 1 1 1 1 0 0 0 0 0 0 0 0 1 1 0 0 0 1
16.下面程序的运行结果是()
main()
{int a[6];
for(I=1;I<6;I++)
{a[I]=9*(I-2+4*(I>3))%5;
printf(“%2d”,a[I]);
}
}
(A)-4 0 4 0 4(B)-4 0 4 0 3(C)-4 0 4 4 3(D)-4 0 4 4 0
17.下列定义正确的是()
(A)static int a[]={1,2,3,4,5}(B)int b[2]={2,5,7}(C)int a(10)(D)int 4e[4]
18.若有说明:int a[][4]={0,0};则下列叙述不正确的是()
(A)数组a的每个元素都可得到初值0(B)二维数组a的第一维的大小为1
(C)因为对二维数组a的初值个数除以第二维的大小,商为0,所以数组a的行数为1
(D)只有元素a[0][0]和a[0][1]可得到初值0,其余元素均得不到初值
19.设有char str[10],下列语句正确的是()
(A)scanf(“%s”,&str);(B)printf(“%c”,str);(C)printf(“%s”,str[0]);(D)printf(“%s”,str);
20.以下语句定义正确的是()(A)int a[1][4]={1,2,3,4,5};(B)float x[3][]={{1},{2},{3}};
(C)long b[2][3]={{1},{1,2},{1,2,3}};(D)double y[][3]={0};
21下列的说法正确的是()
(A)在C语言中,可以使用动态内存分配技术,定义元素个数可变的数组
(B)在C语言中,数组元素的个数可以不确定,允许随机变动
(C)在C语言中,数组元素的数据类型可以不一致(D)在C语言中,定义了一个数组后,就确定了它所容纳的具有相同数据类型元素的个数
22.假设array是一个有十个元素的整型数组,则下列写法中正确的是()
(A)array[0]=10(B)array=0(C)array[10]=0(D)array[-1]=0
23.若用数组名作为函数调用的实参,传递给形参的是()
(A)数组的首地址(B)数组的第一个元素的值(C)数组中全部元素的值(D)数组元素的个数
24.若使用一维数组名作函数实参,则以下正确的说法是()
(A)在被调函数中,与该实参相对应的形参必须是指针型变量
(B)实参数组类型与形参类型可以不匹配
(C)在被调函数中,不需要考虑形参数组的大小(D)实参数组名与形参数组名必须一致
25.下述对C语言字符数组的描述错误的是()(A)字符数组可以存放字符串(B)字符数组中的字符串可以整体输入、输出
(C)可以在赋值语句中通过赋值运算符”=”对字符数组整体赋值
(D)不可以用关系运算符对字符数组中的字符串进行比较
26.设有char str1[10], str2[10],c1; 则下列语句正确的是()
(A)str1 = {“china”}; str2 = str1;(B)c1=”ab”;(C)str1 = {“china”}; str2 = {“people”}; strcpy(str1,str2);(D)c1=‟a‟;
27.以下能正确进行字符串赋值、赋初值的语句组是()
(A)char s[5] = {…a‟,‟b‟,‟c‟,‟d‟,‟e‟};(B)char *s; s=”abcde”;
(C)char s[5] = “abcde”;(D)char s[5]; s = “abcd”; 28.下列语句的执行结果是()
static char str[10] = “china”;
printf(“%d”,strlen(str));
(A)10 (B)6 (C)5 (D)0
29合法的数组定义是()
(A)int a[] = “language”;(B)int a[5]={0,1,2,3,4,5}; (C)char a=”string”;(D)char a[]={“0,1,2,3,4,5”}; 30.若有以下程序片段:
char str[] = “ab\n\012\\\””;
printf(“%d”,strlen(str));
则输出结果是()
(A)3 (B)4 (C)6 (D)12
31.库函数strcpy用以复制字符串。
若有以下定义和语句:
char str1[] = “string”, str2[8], *str3, *str4=”string” ;
则对库函数strcpy的不正确调用是()
(A)strcpy(str1,”hello1”);(B)strcpy(str2,”hello2”);(C)strcpy(str3,”hello3”);(D)strcpy(str4,”hello4”);
32.下面程序段的运行结果是()
char a[7] = “abcdef “;
char b[4] =”ABC”;
strcpy(a,b);
printf(“%c”,a[5]);
(A)为空格(B)\0(C)e(D)f
33.有下面的程序段
char a[3],b[] = “China”;
a = b;
printf(“%s”, a);
则
(A)运行后将输出China(B)运行后将输出Ch(C)输出Chi(D)编译出错
二.填空题
1.数组名命名规则和变量名相同,遵循()命名规则。
2.对于一维数组的定义”类型说明符数组名[常量表达式]”其中常量表达式可以包括()和(),不能包含()。
3.对于数组a[m][n]来说,使用数组的某个元素时,行下标最大值是(),列下标最大值是()。
4.在C语言中,将字符串作为()处理。
5.在C语言中,数组的首地址是()。
6.main()
{int k,*p;
static int a[4]={1,2,3,4};
p = a;
for ( k = 0 ; k < 3 ; k++)
printf(“%d,”, *p++);
}程序的运行结果是()
7.程序
main()
{int k,*p;
static int a[4]={1,2,3,4};
p = a;
for( k = 0; k < 3 ; k ++ )
printf(“%d,”,*++p);
}则运行结果是()
8.下面程序的功能是将字符串s中所有的字符c删除。
补足所缺语
#include <stdio.h>
main()
{
char s[80];
int i , j;
gets(s);
for (i = j = 0; s[i] != …\0‟;i++)
if(s[i] != …c‟) ( );
s[j] = …\0‟;
puts(s);
}
9.下面程序的功能是从键盘输入一行字符,统计其中有多少个单词,单词之间用空格分隔。
补足所缺语句。
#include <stdio.h>
main()
{ char s[80], c1, c2 = … …;
int i = 0, num = 0;
gets(s);
while(s[i] != …\0‟)
{ c1 = s[i];
if(i = = 0 ) c2 = … …;
else c2 = s[i – 1];
if ( ) num + + ;
i ++;
}
printf(“There are %d words.\n”,num);
}
第七章、函数
一.选择题
1. 关于建立函数的目的以下说法正确的是__________。
(A) 提高程序的执行效率
(B) 提高程序的可读性
(C) 减少程序的篇幅
(D) 减少程序文件所占内存
2. 以下说法正确的是__________。
(A) 用户若需调用标准库函数,调用前必须重新定义(B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义
(C) 系统根本不允许用户重新定义标准库函数
(D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文
件包括到用户源文件中,系统自动去调用.
3. 以下函数形式正确的是__________。
(A) double fun(int x,int y)
{ int z=x+y;return z; }
(B) fun(int x,y)
{ int z;
return z; }
(C) fun(x,y)
{ int x,y; double z;
z=x+y; return z; }
(D) double fun(int x,int y);
{ double z;
z=x+y;return z; }
4. 关于C语言以下说法正确的是__________。
(A) 实参和与其对应的形参各占用独立的存储单元
(B) 实参和与其对应的形参共占用一个存储单元
(C) 只有当实参和与其对应的形参同名时才共占用存储单元
(D) 形参是虚拟的,不占用存储单元
5. 若调用一个函数,且此函数中没有return语句,则正确的说法是该函数__________。
(A) 没有返回值
(B) 返回若干个系统默认值
(C) 能返回一个用户所希望的函数值
(D) 有返回值,但返回一个不确定的值
6. 按照C语言的规定以下说法不正确的是__________。
(A) 形参可以是常量、变量或表达式
(B) 实参可以为任意类型
(C) 实参可以是常量、变量或表达式,在传递给形参时,要求实参必须有确定的值
(D) 形参与其对应的实参类型要求可以不一致
7. 以下说法正确的是__________。
(A) 定义函数时,形参的类型说明可以放在函数体内,也可以放在函数体外
(B) return后边的值不能为表达式
(C) 如果函数值的类型与返回值类型不一致,以函数值类型为准
(D) 如果形参与实参的类型不一致,以实参类型为准
8. C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是__________。
(A) 地址传递
(B) 单向值传递
(C) 由实参传给形参,再由形参传回给实参
(D) 由用户指定传递方式
9. C语言允许函数值类型缺省定义,此时该函数值隐含的类型是_______。
(A) float型
(B) int型
(C) long型
(D) double型
10. C语言规定,函数返回值的类型是由__________。
(A) return语句中的表达式类型所决定
(B) 调用该函数时的主调函数类型所决定
(C) 调用该函数时系统临时决定
(D) 在定义该函数时所指定的函数类型决定
11. 下面函数调用语句含有实参的个数为__________。
func((a,b,c,d),(e,f,g));
(A) 1
(B) 2
(C) 4
(D) 以上都不对
12. 以下描述正确的是__________。
(A) 函数调用可以出现在执行语句或表达式中
(B) 函数调用不能做为一个函数的实参
(C) 函数调用可以做为一个函数的形参
(D) 以上都不正确
13. 在C语言程序中,以下描述正确的是__________。
(A) 函数的定义可以嵌套,但函数的调用不可以嵌套(B) 函数的定义不可以嵌套,但函数的调用可以嵌套
(C) 函数的定义和函数的调用均不可以嵌套
(D) 函数的定义和函数的调用均可以嵌套
14. 如果在一个函数的复合语句中定义了一个变量,则该变量_________。
(A) 只在该复合语句中有效,在该复合语句外无效
(B) 在该函数中任何位置都有效
(C) 在本程序的原文件范围内均有效
(D) 此定义方法错误,其变量为非法变量
15. 以下程序的正确运行结果是__________。
#define MAX 10
int a[MAX],i;
main( )
{ printf("\n");sub1();sub3(a);sub2();sub3(a); }
sub2()
{ int a[MAX],i,max;
max=5;
for(i=0;i<max;i++) a[i]=i;
}
sub1()
{ for(i=0;i<MAX;i++) a[i]=i+i;
}
sub3(int a[])
{ int i;
for(i=0;i<MAX;i++) printf("%d",a[i]);
printf("\n");
}
}
(A) 0 2 4 6 8 10 12 14 16 18
0 1 2 3 4
(B) 0 1 2 3 4
0 2 4 6 8 10 12 14 16 18
(C) 0 1 2 3 4 5 6 7 8 9
0 1 2 3 4
(D) 0 2 4 6 8 10 12 14 16 18
0 2 4 6 8 10 12 14 16 18
16. 以下程序的输出结果是__________。
main( )
{
int k=4,m=1,p;
p=func(k,m);
printf("%d,",p);
p=func(k,m);
printf("%d",p);
}
func(int a,int b)
{
static int m,k=2;
k+=m+1;
m=k+a+b;
return(m);
}
(A) 8,17
(B) 8,16
(C) 8,20
(D) 8,8
17. 以下程序的输出结果是__________。
main()
{ int i=1, j=3;
printf("%d,",i++);
{ int i=0; i+=j*2;
printf("%d,%d,",i,j); }
printf("%d,%d\n",i,j); }
(A) 1,6,3,1,3
(B) 1,6,3,2,3
(C) 1,6,3,6,3
(D) 1,7,3,2,3
18. 以下程序的输出结果是__________。
main()
{ int a[]={1,2,3,4},i,x=0;
for(i=0; i<4; i++) { sub(a,&x); printf("%d",x); }
printf("\n");
}
sub(int*s, int *y)
{ static int t=3;
*y=s[t]; t--;
}
(A) 1234
(B) 4321
(C) 0000
(D) 444412.
19. 以下程序的输出结果是__________。
void fun(int *s)
{ static int j=0;
do
s[j]+=s[j+1];
while(++j<2);
}
main( )
{ int k,a[10]={1,2,3,4,5};
for(k=1; k<3; k++) fun(a);
for(k=0; k<5; k++) printf("%d",a[k]);
}
(A) 34756
(B) 23445
(C) 35745
(D) 12345
20. 以下程序的输出结果是__________。
f(int a)
{ int b=0;
static int c=3;
a=c++,b++;
return(a);
}
main( )
{ int a=2,i,k;
for(i=0; i<2; i++) k=f(a++);
printf("%d\n",k);
}
(A) 3
(B) 6
(C) 5
(D) 4
21. 以下程序的输出结果是__________。
int m=13;
int fun2(int x,int y)
{ int m=3;
return(x*y-m);
}
main( )
{ int a=7,b=5;
printf("%d\n",fun2(a,b)/m);
}
(A) 1
(B) 2
(C) 7
(D) 10
22. C语言中,形参缺省的存储类说明是__________。
(A) auto()
(B) static(静态) (C) register(寄存器)
(D) extern(外部)
23. 以下叙述中不正确的是__________。
(A) 一个变量的作用域完全取决于变量定义语句的位置
(B) 全局变量可以在函数以外的任何部位进行定义
(C) 局部变量的"生存期"只限于本次函数调用,因此不可能将局部变量的
运算结果保存至下一次调用
(D) 一个变量说明为static存储类是为了限制其他编译单位的引用
二.填空题
1. 以下程序的输出结果是__________。
main( )
{ int a=3,b=2,c=1;
c-=++b; b*=a+c;
{ int b=5,c=12;
c/=b*2; a-=c;
printf("%d,%d,%d,",a,b,c);
a+=--c;
}
printf("%d,%d,%d\n",a,b,c);
}
2. 以下程序的输出结果是__________。
void fun( )
{ static int a;
a+=2;
printf("%d",a); }
main( )
{ int cc;
for(cc=1; cc<=4; cc++) fun();
printf("\n");
}
3. 以下程序的输出结果是__________。
unsigned funct(unsigned num)
{ unsigned int k=1;
do
{ k*=num%10; num/=10; }
while(num);
return k;
}
main()
{ unsigned int n=26;
printf("funct result is:%d\n",funct(n));
}
4. 以下程序的输出结果是__________。
double sub(double x,double y,double z)
{ y-=1.0; z=z+x; return z; }
main()
{ double a=2.5,b=9.0;
printf("function running result is:%6.1f\n",sub(b-a,a,a));
}
5. 下面pi函数的功能是,根据以下公式返回满足精度ε要求的π的值。
根据以下算法要求补足所缺语句。
π
/2=1+1/3+1/3·2/5+1/3·2/5·3/7+1/3·2/5·3/7·4/9+…
double pi(double eps)
{ double s=0.0,t=1.0;
int n;
for(__________; t>eps; n++)
{ s+=t; t=n*t/(2*n+1); }
return (2.0* __________);
}
第八章、编译预处理
1. 执行下面的程序后,a的值是__________。
#define SQR(X) X*X
main()
{ int a=10,k=2,m=1;
a/=SQR(k+m)/SQR(k+m);
printf("%d\n",a);
}
(A) 10 (B) 1 (C) 9 (D) 0
2. 执行下面的程序后,a的值是__________。
#define SQR(X) X/X
main()
{ int a=10,k=2,m=1;
a/=SQR(k+m)/SQR(k+m);
printf("%d\n",a);
}
(A) 10 (B) 3 (C) 9 (D) Divide error
3. 下面__________不是C语言所提供的预处理功能。
(A) 宏定义(B) 文件包含(C) 条件编译(D) 字符预处理
4. 在宏定义#define MAX 30中,用宏名代替一个_________。
(A) 常量(B) 字符串(C) 整数(D) 长整数
5. 程序
#define NUM 30+4
main()
{ printf("NUM*20=%d",NUM*20); }
的执行结果为__________。
(A) NUM*20=110 (B) NUM*20=680 (C) NUM*20=604
(D) 以上都不对
6. 以下说法正确的是__________。
(A) 宏定义是C语句,所以要在行末加分号
(B) 可以使用#undef命令来终止宏定义的作用域
(C) 在进行宏定义时,宏定义不能层层置换
(D) 对程序中用双引号括起来的字符串内的字符,与宏名相同的要进行置换
7. 下面的说法不正确的是__________。
(A) 函数调用时,先求出实参表达式,然后带入形参。
而使用带参的宏只是进行简单的字符替换
(B) 函数调用是在程序运行时处理的,分配临时的内存单元。
而宏展开则是在编译时进行的,在展开时也要分配内存单元,进行值传递
(C) 对于函数中的实参和形参都要定义类型,二者的类型要求一致,而宏不存在类型问题,宏没有类型
(D) 调用函数只可得到一个返回值,而用宏可以设法得到几个结果
8. 下面的说法不正确的是__________。
(A) 使用宏的次数较多时,宏展开后源程序长度增长。
而函数调用不会使源程序变长
(B) 函数调用是在程序运行时处理的,分配临时的内存单元。
而宏展开则是在编译时进行的,在展开时不分配内存单元,不进行值传递
(C) 宏替换占用编译时间
(D) 函数调用占用编译时间
9. 对于文件包含处理,在编译时__________。
(A) 把用#include 命令指定的文件与本文件用link命令进行联接
(B) 把用#include 命令指定的文件与本文件用project 命令进行联接
(C) 把用#include 命令指定的文件与本文件进行宏替换
(D) 把用#include 命令指定的文件与本文件作为一个源文件进行编译
10. 以下叙述中正确的是__________。
(A) 用#include包含的头文件的后缀不可以是".a"
(B) 若一些源程序中包含某个头文件;当该头文件有错时,只需对该头文件进行修改,包含此头文件所有源程序不必重新进行编译
(C) 宏命令行可以看做是一行C语句
(D) C编译中的预处理是在编译之前进行的
11. 将大写字母变为小写字母的宏定义为__________。
(A) #define TOLOWER(ch)
(ch>='A')&&(ch<='Z')? ch+26:ch?
(B) #define TOLOWER(ch)。