C语言试题

Python022

C语言试题,第1张

1、一个C语言程序的语句至少应包含一个___main函数___。

2、C语言源程序文件的扩展名是__ .C ____,经过编译、连接后,生成文件的扩展名是__ .h ____。

3、结构化程序由顺序结构、___选择___和___循环___三种基本结构组成。

4、C语言的执行是从____main函数__开始执行的。

5、C源程序的语句分隔符是___分号___。

6、在C语言中,用关键字_____float_定义单精度实型变量

7、表达式S=12应当读做“___把12赋值给S___”。

8、C语言源程序的基本单位是___函数___。

9、设int x=9,y=8;表达式x-=y+1的结果是___0___。

10、若a为整型变量,a=12,则表达式:a * =2+3的值___60__。

11、调用C语言对输入输出处理的库函数时,在# include命令行中应包含的头文件是___stdio.h___。

12、表达式9%5的结果是__4____。

13、若a为整型变量,a=12,则表达式:a+=4的值_16_____。

14、 在C语言中,要求运算数必须是整型的运算符是__%____。

15、在C语言中,用____非零整数__表示逻辑“真”值。

16、表达式10/3的结果是__3____。

17、通常一个字节包含__8____个二进制位。

18、 假设所有变量均为整型,a=2,b=5,b++则表达式a+b的值是_8_____。

19、在C语言中,最基本的数据类型只有四种,它们分别是:_int_____、___float___、__char____和double。

20、一个C程序有且仅有一个____main__函数。

21、若a为整型变量,a=12,则表达式:a-=2的值_10____。

22、在C语言中,有三种逻辑运算符,它们分别是:__与____、___或___、__非____。

23、在C语言中,字符输入函数和字符输出函数分别是:__getchar____和___putchar___。

24、C程序开发的四个步骤是___输入与编辑源程序___、__编译____、__连接____和执行。

25、C程序的结构分别是:顺序结构、__选择结构____、__循环结构____。

26、if语句中的表达式可以是关系表达式、__算术表达式____、__赋值表达式____。

27、__x>y_?x:y___是C语言中惟一一个三元运算符。

28、C语言提供的预处理命令主要包括如下三种:宏定义、__文件包含____、___条件编译___。

二、阅读程序,写出下列程序运行结果。

1、2

2、K

3、a 97

4、无结果

三、编写程序

1、编写一个C程序,输入a、b、c 3个数,输出其中最大的数。

#include

Void main()

{

Int a,b,c

Printf("请输入三个数")

Scanf(%d%d%d,&a,&b,&c)

If(a<b)

A=b

If(a<c)

A=c

Printf("最大的数:%d",a)

}

求1—50的之和。

#include

Void mian()

{

Int sum=0,i

For(i=1i<=50i++)

Sum+=i

Printf("1-50之和为:%d",sum)

}

从键盘输入一个大写字母,要求改用小写字母输出。

#include

Void mian()

{

Char c

Printf("请输入一个字母")

Scanf("%c".&c)

Printf("它的小写字母为%c",c+32)

}

利用while语句,计算1+1/2+1/4+…+1/100的值,并显示出来。

#include

Void mian()

{

Float sum=0,temp

Int i =1

While(i<=100)

{

Temp=1/i

Sum+=temp

I++

}

Printf("结果为%d",sum)

}

输入两个整数,输出其中的大数。

#include

Void mian()

{

Int a,b

Printf("请输入两个数")

Scanf("%d%d".&a,&b)

Printf("大数是:%d"a>b?a:b)

}

6、利用while语句,计算1+1/3+1/5+…+1/99的值,并显示出来。

#include

Void mian()

{

Int i =1

Float sum=0,temp=0

While(i<=99)

{

Temp =1/i

Sum+=temp

I=i+2

}

Printf("结果为: %f",sum),

}

main()

{ int k, a[10]={1,2,3,4,5}

for(k=1k<3k++) fun(a)

for(k=0k<5k++) printf("%d", a[k])

}

上面程序的输出结果是

A.34756

B.23445

C.35743

D.12345

(40) 请读程序:

#include

#define SUB(X,Y) (X)*Y

main()

{ int a=3, b=4

printf("%d", SUB(a++, b++))

}

上面程序的输出结果是

A.12

B.15

C.16

D.20(41) 请读程序:

#include

main()

{ int mun=0

while(num<=2)

{ num++printf("%d\n",num)}

}

上面程序的输出结果是

A.1

B.1

C.1

D.1

2 2 2

3 3

4

(42) 请读程序:

#include

main()

{ float x,y

scan("%f",&x)

if(x<0.0) y=0.0

else if((x<5.0)&&(x!=2.0))

y=1.0/(x+2.0)

else if (x<10.0) y=1.0/x

else y=10.0

printf("%f\n",y)

}

若运行时从键盘上输入2.0(表示回车),则上面程序的输出结果是

A.0.000000

B.0.250000

C.0.500000

D.1.000000

(43) 请读程序:

#include

main()

{ int x=1, y=0, a=0, b=0

switch(x)

{ case 1:

switch(y)

{ case 0: a++break

case 1: b++break

}

case 2:

a++b++break

}

printf("a=%d, b=%d\n",a,

B.

}

上面程序的输出结果是

A.a=2, b=1

B.a=1, b=1

C.a=1, b=0

D.a=2, b=2

(44) 若有下面的程序片段:

int a[12]={0}, *p[3], **pp, i

for(i=0i<3i++)

p[i]=&a[i*4]

pp=p

则对数组元素的错误引用是

A.pp[0][1]

B.a[10]

C.p[3][1]

D.*(*(p+2)+2)

(45) 请读程序:

#include

#include

main()

{ float x,y,z

scan("%f%f",&x,&y)

z=x/y

while(1)

{ if(fabs(z)>1.0)

{ x=yy=zz=x/y

}

else break

}

printf("%f\n",y)

}

若运行时从键盘上输入3.6 2.4(表示回车),则输出的结果是

A.1.500000

B.1.600000

C.2.000000

D.2.400000

(46) 请读程序:

#include

f(in b[], int n)

{ int i, r

r=1

for(i=0i<=ni++) r=r*b[i]

return r

}

main()

{ int x, a[]={ 2,3,4,5,6,7,8,9}

x=f(a, 3)

printf("%d\n",x)

}

上面程序的输出结果是

A.720

B.120

C.24

D.6

(47) 请读程序:

#include

#include

void fun( char *s)

{ char a[10]

strcpy( a, "STRING")

s=a

}

main()

{ char *p

fun(p)

x=f(a, 3)

printf("%s\n",p)

}

上面程序的输出结果是(└┘表示空格)

A.STRING└┘└┘└┘└┘

B.STRING

C.STRING└┘└┘└┘

D.不确定的值

(48) 若已建立下面的链表结构,指针p、s分别指向图中所示的结点,则不能将s所指的结点插入到链表末尾的语句组是

A.s->next=NULLp=p->nextp->next=s

B.p=p->nexts->next=p->nextp->next=s

C.p=p->nexts->next=pp->next=s

D.p=(*p).next(*s).next=(*p).next(*p).next=s

(49) 请读程序:

#include

void fun(float *pl, float *p2, float *s)

{ s=( float * )calloc( 1, sizeof(float))

*s=*p1+ *(p2++)

}

main()

{ float a[2]={1.1, 2.2}, b[2]={10.0, 20.0}, *s=a

fun(a, b, s)

printf("%f\n",*s)

}

上面程序的输出结果是

A.11.100000

B.12.100000

C.21.100000

D.1.100000

(50) 请读程序:

#include

#include

void fun( char *w, int m)

{ char s, *p1, *p2

p1=wp2=w+m-1

while (p1{ s=*p1++*p1=*p2--*p2=s}

}

main()

{ char a[]="ABCDEFG"

fun( a, strlen(a))

puts(a)

}

上面程序的输出结果是

A.GFEDCBA

B.AGADAGA

C.AGAAGAG

D.GAGGAGA

二、填空题(每空2分,共40分)

请将每空的正确答案写在答题卡上【1】-【20】序号后的横线上,答在试卷上不得分。

(1) DOS命令分为内部命令与外部命令,XCOPY命令是 【1】 命令

(2) 为了列出当前盘当前目录中所有第三个字符为C的文件名的有关信息,应该用命令 【2】 。

(3) 设当前盘为A盘,当前目录为\X\Y,A盘上的一个文件QR.C在当前目录下的子目录W中。现已将A盘的当前目录改为\D\XY,当前盘改为C盘,如需指定A盘上该文件应写成 【3】 。

(4) 用十六进制给存储器中的字节地址进行编号,其地址编号是从0000到FFFF,则该存储器的容量是【4】KB。

(5) 设有两个八位二进制数00010101与01000111相加,其结果的十进制表示为 【5】 。

(6) 数学式子 写成C语言表达式是 【6】 。

(7) 下面程序的输出结果是 【7】 。

#include

main()

{ static char b[]="Goodbye"

char *chp=&b[7]

while( --chp >=&b[0]) putchar( *chp)

putchar(’\n’)

}

(8) 下面程序的输出结果是 【8】 。

#include

void as( int x, int y, int *cp, int *dp)

{ *cp=x+y

*dp=x-y

}

main()

{ int a=4, b=3, c, d

as( a, b, &c, &d)

printf( ’%d %d\n", c, d)

}

(9) 请读程序:

#include

main( int argc, char *argv[])

{ int i

printf( ’%d\n", argc)

for( i=0i<=argc+1i++) printf( "%s ", argv[i])

printf("\n")

}

若上面的程序编译、连接后生成可执行文件ABC.EXE,则输入以下命令行

abc file1 file2(表示回车)

程序执行后的输出结果是 【9】 。

(10) 条件“20(11) 设二进制数a是00101101,若想通过异或运算a^b使a的高4位取反,低4位不变,则二进制数b应是 【11】 。

(12) 若有以下说明和定义语句,则变量w在内存中所占的字节数是 【12】 。

union aa

{ float x, y

char c[6]

}

struct st { union aa vfloat w[5]double ave} w

(13) 下面程序的输出结果是 【13】 。

#include

#define N 5

fun( char *s, char a, int n)

{ int j

*s=aj=n

while( ereturn j

}

main()

{ char s[N+1]

int k, p

for( k=1k<=Nk++)

s[k]=’A’+k+1

printf( "%d\n", fun(s, ’E’, N))

}(14) 下面程序的输出结果是 【14】 。

#include

void fun( char *a1, char *a2, int n)

{ int k

for( k=0ka2[k]=( a1[k]-’A’-3+26)&+’A’

a2[n]=’\0’

}

main()

{ char s1[5]="ABCD", s2[5]

fun( s1, s2, 4)

puts( s2)

}

(15) 下面的findmax函数返回数组s中最大元素的下标,数组中元素的个数由t传入,请填空。

findmax( int s[], int t)

{ int k, p

for( p=0, k=ppif( s[p]>s[k]) 【15】 。

return k

}

(16) 下面程序的输出结果是 【16】 。

#include

fun( int x)

{ int p

if( x==0||x==1) return(3)

p=x-fun( x-2)

return p

}

main()

{ printf( "%d\n", fun(9))}

(17) 下面程序的输出结果是 【17】 。

#include

funa( int a, int b)

{ return a+b}

funb( int a, int b)

{ return a-b}

sub( int (*t)(), int x, int y)

{ return((*t)( x,y))}

main()

{ int x, (*p)()

p=funa

x=sub(p,9,3)

x+=sub(funb, 8, 3)

printf("%d\n", x)

}

(18) 下面程序的输出结果是 【18】 。

#include

main()

{ char *p[]={ "BOOL", "OPK", "H", "SP"}

int i

for(i=3i>=0i--,i--) printf( "%c", *p[i])

printf("\n")

}

(19) 为了建立如图所示的存储结构(即每个结点含两个域,data是数据域,next是向结点的指针域),请填空。

data next

struct link { char data【19】 } node

(20) 下面的程序用来统计文件中字符的个数,请填空。

#include

main()

{ FILE *fp

long num=0

if(( fp=fopen("fname.dat","r"))==NULL)

{ printf( "Can’t open file! \n")exit(0)}

while 【20】

{ fgetc(fp)num++}

printf("num=%d\n", num)

fclose(fp)

}

参考答案

一`选择题((1)~(40)题每题1分,(41)~(50)题每题2分,共60分)

(1)C (2)A (3)B (4)D (5)D (6)A (7)C (8)B (9)D (10)C

(11)B (12)D (13)A (14)C (15)B (16)A (17)B (18)A (19)C (20)C

(21)D (22)B (23)B (24)A (25)C (26)D (27)D (28)B (29)C (30)A

(31)B (32)B (33)D (34)C (35)A (36)C (37)A (38)B (39)C (40)A

(41)C (42)C (43)A (44)C (45)B (46)B (47)D (48)C (49)D (50)C

二` 填空题(每空2分,共40分)

(第(2)`(3)空允许小写或大小写混合使用,其它空均须与答案一样)

(1) 外部

(2) DIR ?? C*.*

(3) A:\X\Y\W\QR.C

(4) 64

(5) 92

(6) pow(sin(x),2) * (a+b)/(a-b) 或 sit(x) * sit(x) * (a+b)/(a-b)

(7) eybdooG

(8) 7 1

(9) 3 abc.exe file1 file2 (注:两个答案,每个1分)

(10) ((20 (11) 11110000

(12) 34

(13) 3

(14) XYZA

(15) k=p

(16) 7

(17) 17

(18) SO

(19) struct link *next

(20) (!feof(fp))或(feof(fp)==0)

你看这行吗? C语言试题(10)选择题(50×2=100)1.以下叙述正确的是( )。A)在C程序中,main函数必须位于程序的最前面B)C程序的每行中只能写一条语句C)C语言本身没有输入输出语句D)在对一个C程序进行编译的过程中,可发现注释中的拼写错误2.C语言规定:在一个源程序中,main函数的位置( )。A)必须在最开始B)必须在系统调用的库函数的后面C)可以任意D)必须在最后3.在C语言中(以16位PC机为例),5种基本数据类型的存储空间长度的排列顺序为( )。A)char<int <1ong int<=float<doubleB)char=int<1ong int<=float<doubleC)char< int <1ong int=float=doubleD)char=int =1ong int<=float<double4.假设所有变量均为整型,则表达式(a=2,b=5,b++,a+b)的值是( )。 A)7B)8 C)6 D)25.下面四个选项中,均是C语言关键字的选项是( )。A)auto B)switchC)signedD)if enum typedef union struct include continue scanf type6.C语言中的标识符只能由字母、数字和下划线三种字符组成,且第一个字符( )。 A)必须为字母B)必须为下划线 C)必须为字母或下划线D)可以是字母,数字和下划线中任一种字符7.下面四个选项中,均是不合法的转义字符的选项是( )。 A)'\'' B)'\1011'C)'\011'D)'\abc''\\' '\''\f' '\101'8.若有代数式3ae/bc,则不正确的C语言表达式是( )。 A) a/b/c*e*3 B)3*a*e/b/c C)3*a*e/b*c D)a*e/c/b*39.已知各变量的类型说明如下: int i=8,k,a,bunsigned long w=5double x=1.42,y=5.2则以下符合C语言语法的表达式是( )。A) a+=a-=(b= 4)*(a=3) B)a=a*3=2C) x%(-3)D)y=f1oat(i)10.以下正确的叙述是( )。A)在C程序中,每行中只能写一条语句B)若a是实型变量,C程序中允许赋值a=10,因此实型变量中允许存放整型数C)在C程序中,无论是整数还是实数,都能被准确无误地表示D)在C程序中,%是只能用于整数运算的运算符11.已知字母A的ASCII码为十进制数65,且c2为字符型,则执行语句c2='A'+'6'-'3'后,c2中的值为( )。A)D B)68 C)不确定的值 D)C12.若以下变量均是整型,且num=sum=7则执行表达式sum=num++,sum++,++num后sum的值为( )。 A) 7B) 8 C) 9 D) 1013.若有说明语句:char c='\72'则变量c( )。A)包含1个字符 B)包含2个字符C)包含3个字符 D)说明不合法,c的值不确定14.下面四个选项中,均是非法常量的选项是( )。A)'as' B)'\\' c)-0xl8D)0xabc -0fff '\01'01177 '\0' '\0xa' 12,456 0xf"a"15.设变量n为f1oat类型,m为int类型,则以下能实现将n中的数值保留小数点后两位,第三位进行四舍五人运算的表达式是( )。A) n=(n*100+0.5)/100.0 B)m=n*100+0.5 ,n= m/100.0C) n=n*100+0.5/100.0 D)n=(n/100+0.5)*100.016.设C语言中,一个int型数据在内存中占2个字节,则unsigned int型数据的取值范围为( )。A) 0~255 B) 0~32767 C) 0~65535 D) 0~214748364717.若有以下定义,则能使值为3的表达式是( )。int k= 7,x =12A) x%=(k%= 5) B) x%=(k一k%5)C) x%=k- k%5D) (x%=k)一(k%=5)18.putchar函数可以向终端输出一个( )。A)整型变量表达式值B)实型变量值C)字符串D)字符或字符型变量值19.printf函数中用到格式符%5s ,其中数字5表示输出的字符串占用5列。如果字符串长度小于5,则输出按方式( )。A)从左起输出该字串,右补空格B)按原字符长从左向右全部输出C)右对齐输出该字串,左补空格D)输出错误信息20.若x ,y均定义为int型,z定义为double型,以下不合法的scanf函数调用语句是( )。A) scanf(" %d%lx,%le",&x,&y,&z)B) scanf("%2d * %d%lf"&x,&y,&z )C) scanf("%x %* d%o",&x,&y)D) scanf("%x%o%6.2f",&x,&y,&z)21.已有定义int x f1oat y且执行scanf("%3d%f",&x,&y)语句,若从第一列开始输入数据12345 678(回车),则x 的值为( )。A)12345B)123C) 45 D) 345 22.已有如下定义和输入语句,若要求a1,a2,c1,c2的值分别为10,20,A,B,当从第一列开始输入数据时,正确的数据输入方式是( )。int a1,a2 char c1,c2scanf("%d%d",&a1,&a2)scanf("%c%c",&c1,&c2)A) 1020AB<CR> B)10 20<CR>AB<CR>C)10 20 AB<CR> D)10 20AB<CR>23.以下能正确地定义整型变量a,b和c 并为其赋初值5的语句是( )。 A)int a=b= c= 5 B) int a,b, c= 5C)a= 5,b=5,c=5 D) a= b= c=524.已知ch是字符型变量,下面正确的赋值语句是( )。A) ch= '123' B) ch= '\xff' C) ch= '\08' D) ch="\"25.设x 、y均为f1oat型变量,则以下不合法的赋值语句是( )。A)++x B)y=(x%2)/10C) x*=y+8 D)x=y=026.逻辑运算符两侧运算对象的数据类型( )。 A)只能是0或1 B)只能是0或非0正数 C)只能是整型或字符型数据 D)可以是任何类型的数据27.下列运算符中优先级最高的是( )。 A)< B)十 C)&&D)!=28.设x,y 和z是int型变量,且x = 3,y= 4,z= 5,则下面表达式中值为0的是( )。 A)'y'&&'y' B)x <=y C) x||y+z&&y-z D) !(x<y)&&!z||1)29.判断char型变量c1是否为小写字母 正确表达式为( )。A)' a' <=cl<=' z'B) (cl>= a)&&(cl<=z)C)(' a' >=cl)||(' z' <= cl) D)(c1>='a')&&(cl<='z')30.执行以下语句后a的值为( )。int a,b,ca= b= c= 1++a||++b&&++c A)错误 B) 0 C) 2 D) 131.以下符合c语言语法的赋值表达式是( )。A)d=9+e+f=d+9 B)J=9+e,f=d+9C)d=9+e,e++,d+9 D)d=9+e++=d+732.若有代数式3ae/bc,则不正确的c语言表达式是( )。A)a/b/c*e*3 B)3*a*e/b/cC)3*a*e/b*c D)a*e/c/b*e33.已知各变量的类型说明如下int k,a,bunsigned long w=5double x=1.422;则以下不符合c语言语法的表达式是( )。A)x%(-3) B)w+=-2C)k=(a=2,b=3,a+b) D)a+=a-=(b=4)x(a=3)34.已知字母A的ASCII码为+进制数65,且c2为字符型,则执行语句c2='A'+'6'-'3'后,c2中的值为( )。A)D B) 68C)不确定的值 D)C35.若有以下定义:int a,b float x,则正确的赋值语句是( )。A)a=1,b=2,B)b++C)a=b=5 D)b=int(x)36.c语言中的标识符只能由字母、数字和下划线三种字符组成,且第一个字符( )。A)必须为字母B)必须为下划线C)必须为字母或下划线D)可以是字母、数字和下划线中任-种字符37.在c语言中,char型数据在内存中的存储形式是( )。A)补码 B)反码 C)原码 D)ASCII码38.若有说明语句:char c='72'则变量c( )。A)包含1个字符B)2个字符C)包含3个字符D)说明不合法,c的值不确定39.己知各变量的类型说明如下:int i=8,k,a,bunsigned long w=55double x=1.42,y=5.2则以下符合c语言语法的表达式是( )。A)+=a-=(b=4)*(a=3)B)a=a*3=2C)x%(-3)D)y=float(i)40.若以下变量均是整型,且num=sum=7则执行表达式sum=num++, sum++,++num后sum的值为( )。A)7B)8C)9D)1041.若有定义:int a=7folat x=2.5,y=4.7则表达式x+a%3*(int)(x+y)%2/4的值是( )。A)2.500000 B)2.750000 C)3.500000 D)0.00000042.设有说明:char wint x,float ydouble z则表达式w*x+z-y值的数据类型为( )。A)float B)char C) int D)double43.设变量n为float类型,m为int 类型,则以下能实现将n中的数值保留小数点后两位,第三位进行四舍五入运算的表达式是( )。A)n=(n*100+0.5)/100.0 B)m=n*100+0.5,n=m/100.0C)n=n*100+0.5/100.0D)n=(n/100+0.5)*100.044.以下关于运算符优先顺序的描述中正确的是( )。A)关系运算符<算术运算符<赋值运算符<逻辑与运算符B)逻辑与运算符<关系运算符<算术运算符<赋值运算符C)赋值运算符<迟辑与运算符<关系运算符<算术运算符D)算术运算符<关系运算符<赋值运算符<逻辑与运算符45.判断char型变量ch是否为大写字母的正确表达式是( )。A) 'A'<=ch<='Z' B)(ch>='A')&(ch<='Z')C)(ch>='A')&&(ch<+'Z') D)('A'<=ch)AND('Z'>=ch46.下列运算符中优先级最高的是( )。A)< B)+ C)&& D)!=47.执行以下语句后a的值为( )。int a=5,b=6,w=1,x=2,y=3,z=4(a=w>x)&&(b=y>z)A)5B)0C)2D)148.已知 x=43,ch='A',y=0则表达式(x>=y&&ch<'B'&&!y)的值是( )。A)0 B)语法错 C)1D) "假"49.设x、y和s是int型变量,且x=3,y=4,z=5,则下面表达式中值为0的是( )。A)'x'&&'y'B)x<=yC)x||y+z&&y-zD)!((x<y)&&!z50.以下不正确的if语句形式是( )。A) if(x>y&&x!=y)B)if(x==y)x+=yC)if(x!=y) scanf("%d",&x) else scanf("%d",&y)D) if(x<y){x++y++}