计算机二级资料分享_第1页
计算机二级资料分享_第2页
计算机二级资料分享_第3页
计算机二级资料分享_第4页
计算机二级资料分享_第5页
已阅读5页,还剩55页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C语言概述

一单项选择题

1.一个C程序的执行是从(A)。

A)本程序的main函数开始,到main函数结束

B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束

C)本程序的main函数开始,到本程序文件的最后一个函数结束

D)本程序文件的第一个函数开始,到本程序的main函数结束

2.以下叙述正确的是(C)。

A)在C程序中,main函数必须位于程序的最前面

B)C程序的每行中只能写一条语句

C)C语言本身没有输入输出语句

D)在对一个C程序进行编译的过程中,可发现注释中的拼写错误

3.以下叙述不正确的是(D)。

A)一个C源程序可由一个或多个函数组成

B)一个C源程序必须包含一个main函数

C)C程序的基本组成单位是函数

D)在C程序中,注释说明只能位于一条语句的后面

4.C语言规定,在一个源程序中,main函数的位置(C)。

A)必须在最开始

B)必须在系统调用的库函数的后面

C)可以任意

D)必须在最后

5.一个C语言源程序是由(B

A)一个主程序和若干子程序组成

B)函数组成

C)若干过程组成

D)若干子程序组成

二填空题

1.C源程序的基本单位是函数。

2.一个C源程序中至少应包括一个main函数,,

3.在一个C源程序中,注释部分两侧的分界符分别为国和父。

4.一个函数是由两部分组成的,它们分别是函数首部和函数体。

5.在C语言中,一个函数的函数体一般包括声明部分和执行部分。

6.在每个C语句和数据定义的最后必须有一个一。

7.C语言本身没有输入输出语句。其输入输出是山函数来完成。

8.程序是指一组能使计算机识别和执行的指令,每一个指令都使计算机能够执行相应

的操作。。

9.源程序是指用高级语言编写的程序。C源程序文件的扩展名为的。

10.目标程序是指计算机不能识别和执行高级语言程序,只能通过高编译系统将高级

语言程序转化为二进制的目标程序。目标程序文件的扩展名为

11.可执行程序是指将目标函数和系统的函数库以及其它目标函数链接起来行程可执

行程序。可执行程序文件的扩展名为3。

12.上机运行一个C源程序的步骤一般为:①输入和编辑源程序;②编译源程序;

③连接库函数;④生成可执行程序。

一、单项选择题

1.下面四个选项中,均不是c语言关键字的选项是(A)o

A)defineIFType

B)getccharprintf

C)includescanfcase

D)whilegopow

2.C语言中的标识符只能由字母、数字和下划线三种字符组成,且第一个字符(C)。

A)必须为字母

B)必须为下划线

C)必须为字母或下划线

D)可以是字母、数字和下划线中任一种字符

3.下列四个选项中,均是C语言关键字的选项是(B)。

A)autoenuminclude

B)switchtypcdefcontinue

C)signedunionscanf

D)ifstructtype

4.下面四个选项中,均是不合法的用户标识符的选项是(C)。

A)APOdo

B)floatlaO_A

C)b-agotoint

D)_123tempint

5.以下有4组用户标识符,其中合法的一组是(C)。

A)For-subCase

B)4dDOSize

C)f2_G3IFabc

D)WORDvoiddefine

6.下列选项中,合法的C语言关键字是(D)o

A)VAR

B)cher

C)integer

D)default

7.下面四个选项中,均是合法整型常量的选项是(A)。

A)160-OxfffiOll

B)-OxcdfOlaOxe

C)-019860120668

D)-0x48a0x2e5Oxe

8.下面四个选项中,均是正确的八进制数或十六进制数的选项是(C)。

A)・100x80011

B)0abc-017Oxc

C)010-0x11Oxfl

D)0a12-0x123-Oxa

9.设C语言中,-个int型数据在内存中占2个字节,则unsignedint型数据的取值范

围为(C

A)0-255

B)0〜32767

C)0-65535

D)0-2147483647

10.在C语言中,不正确的血类型的常数是(A)。

A)32768

B)0

C)037

D)0xAF(l1101111=128+64+32+8+4+2-1-1)

11.下面四个选项中,均是不合法的整型常量的选项是(D)。

A)-Ofl-OxffiTOOH

B)-OxcdfD1712456

C)-0189995e2

D)-0x48eg-06803f

12.下面四个选项中,均是不合法的浮点数的选项是(B)。

A)160.0.12e3

B)1232e4.2.e5

C)-.18123e40.0

D)-e3.234le3

13.下面四个选项中,均是合法的浮点数的选项是(B)o

A)+le+l5e-9.403e2

B)-.6012e-4-8e5

C)123el.2e-.4+2e-l

D)-e3.8e-45.e-0

14.下列变量定义中合法的是(A)o

A)short_a=l-.le-l;

B)doubleb=l+5e2.5;

C)longdo=0xfdaL;

D)float2_and=l-e-3;

15.以下选项中合法的字符常量是(B)。

A)

B)''010'

C)68

D)D

16.以下选项中,非法的字符常量是(C)。

A)V

B)M7,

C)

D)^xaa,

17.以下所列的C语言常量中,错误的是(B)o

A)OxFF

B)1.2e0.5

C)2L

D),72,

18.在C语言中,char型数据在内存中的存储形式是(D)。

A)补码

B)反码

C)原码

D)ASCH码

19.下面四个选项中,均是合法转义字符的选项是(A)o

A)

B)4\017,V,

C)''018''\f''xab'

D)'\\0'''101''xlf'

20.下面四个选项中,均是不合法的转义字符的选项是(B)。

A”\"\W

B)AIOIT4?'\a'

C),\01「\ff},

D)'\abc'''101''xlf'

21.下面正确的字符常量是(C)。

A)"c”

B)N”

C)'W,

D)”

22.下面四个选项中,均是正确的数值常量或字符常量的选项是(D)o

A)0.00f8.9e

B)ta,3.9e-2.51erV,

C)'3'0110xfTO00a

D)+001Oxabcd2e250.

23.下面不正确的字符串常量是(A)

A)匕be'

B)“⑵2”

C)"0"

D),,,,

24.在C语言中(以16位PC机为例),5种基本数据类型的存储空间长度的排列顺序为

(A)o

A)char<int<longint<=float<double

B)char=int<longint<=float<double

C)char<int<longint=float=double

D)char=int=longint<=float<double

25.若有说明语句:char0=^72>;则变量c(A)。

A)包含1个字符

B)包含2个字符

C)包含3个字符

D)说明不合法,c的值不确定

26.设变量a是整型,f是实型,i是双精度型,则表达式10+a+i*f值的数据类型为(C)。

A)int

B)float

C)double

D)不确定

27.表达式18表*sqrt(4.0)/8值的数据类型为(C)。

A)int

B)float

C)double

D)不确定

28.设有说明:charw;intx;floaty;doublez;则表达式w*x+z-y值的数据类型为

(D)o

A)float

B)char

C)int

D)double

29.以下选项中属于C语言的数据类型是(C)。

A)复数型

B)逻辑型

C)双精度型

D)集合型

30.以下程序的输出结果是(A)

main()

{

charc='z';

printf("%c”,c-25);

)

A)a

B)Z

C)z-25

D)y

31.若有定义:inta=7;floatx=2.5,y=4.7;则表达式x+a%3*(int)(x+y)%2/4的值是(A)。

A)2.500000

B)2.750000

C)3.500000

D)0.000000

32.若有代数式3ae/bc,则不正确的c语言表达式是(C)。

A)a/b/c*e*3

B)3*a*e/b/c

C)3*a*e/b*c

D)a*e/c/b*3

33.设有intx=ll;则表达式(x++*1/3)的值是(A)。

A)3

B)4

C)11来源:www.examda.com

D)12

34.以下变量x.、y、z均为double类型且已正确赋值,不能正确表示数学式子x/yz的

C语言表达式是(A)。

A)x/y*z

B)x*(l/(y*z))

C)x/y*l/z

D)x/y/z

35.C语言中运算对象必须是整型的运算符是(A)。

A)%=

B)/

C)=

D)<=

36.下列程序的输出结果是(C)。

main()

{

doubled=3.2;intx,y;

x=1.2;y=(x+3.8)/5.0;

printf(n%d\nM,d*y);

}

A)3

B)3.2

C)0

D)3.07

37.若x,i,j和k都是int型变量,则计算下面表达式x=(i=4,j=16,k=32)后,x的值

为(C

A)4

B)16

C)32

D)52

38.假设所有变量均为整型,则表达式(a=2,b=5,b++,a+B)的值是(B)。

A)7

B)8

C)6

D)2

39.假定x和y为double型,则表达式x=2,y=x+3/2的值是(D)。

A)3.500000

B)3

C)2.000000

D)3.000000

40.若以下变量均是整型,且num=sum=7;则计算表达式sum=num++,sum++,++num

后sum的值为(B

A)7

B)8

C)9

D)10

41.若有定义intk=7,x=12;,则以下能使值为3的表达式是(D)。

A)x%=(k%=5)

B)x%=(k・k%5)

C)x%=k-k%5

D)(x%=k)-(k%=5)

42.设以下变量均为int类型,则值不等于7的表达式是(C)。

A)(x=y=6,x+y,x+l)

B)(x=y=6,x+y,y+l)

C)(x=6,x+l,y=6,x+y)

D)(y=6,y+l,x=y,x+l)

43.下列程序执行后的输出结果是(A)。

main()

{

intx=f;

printf("%c\n'','A'+(x・'a'+l));

)

A)G

B)H

C)I

D)J

44.下列程序执行后的输出结果是(C)。

main()

{charx=OxFFFF;printf("%d\nM,x—);}

A)-32767

B)FFFE

C)-l

D)-32768

45.以下程序的输出结果是(D)。

main()

{inta=3;

printf(M%d\nn,(a+=a-=a*a));

)

A)-6

B)12

C)0

D)-12

46.若变量已正确定义并赋值,下面符合C语言语法的表达式是(B)。

A)a:=b+l

B)a=b=c+2

C)int18.5%3

D)a=a+7=c+b

47.若有以下程序段,

intcl=l,c2=2,c3;

c3=1.0/c2*cl;

则执行后,c3中的值是(A)o

A)0

B)0.5

C)1

D)2

48.有如下程序

main()

{inty=3,x=3,z=l;

printff4%d%d\n”,(十+x,y++),z+2);

}

运行该程序的输出结果是(D)。

A)34

B)42

C)43

D)33

49.已知大写字母A的ASCII码为65,以下程序的运行结果为(A)。

#include<stdio.h>

main()

{

charcl='A',c2='Y';

printf("%d,%d\rT,cl,c2);

}

A)65,89

B)A,Y

C)65,88

D)65,90

50.以下程序的输出结果是(D)。

#include<stdio.h>

main()

(

inta=010,b=10;

printf("%d,%d\n”,a++,--B);

}

A)10,10

B)8,10

C)10,9

D)8,9

51.以下程序的输出结果是(B)o

main()

{

inta,b;

a=100;b=200;

printf("%d\n”,(a,

B));

A)100

B)200

C)20000

D)100=200

52.执行语句y=10;x=y-H-;的结果是(C)。

A)x=10,y=10

B)x=ll,y=ll

C)x=10,y=ll

D)x=ll,y=10

53.在表示C语言的整型变量时,表示“无符号长整型”的符号是(D)o

A)unsignedint

B)unsignedshort

C)longint

D)unsignedlong

54.在下列形式的常数中,C程序不允许出现的是(B)o

A).45

B)±123

C)25.6e-2

D)4e3

55.以下程序的输出结果是(C)o

main()

{floatx=3.6;

inti;

i=(int)x;

printfC4x=%f,i=%d,,,x,i);

}

A)x=3.600000,i=4

B)x=3,i=3

C)x=3.600000,i=3

D)x=3.000000,i=3.600000

56.在C语言中,要求运算数必须是整型数据的运算符是(B)。

A)/

B)%

C)!

D)<

57.执行下列语句的结果是(C)。

i=3;

printf(“%d,”,++i);

printf("%d”,i++);

A)3,3

B)3,4

C)4,3

D)4,4

58.已知x=3,y=2,则表达式x*=y+8的值为(C)<>

A)3

B)2

C)30

D)14

59.执行语句inti=65536;printf("%d\rT,i);的结果是(B)。

A)65536

B)0

C)有语法错误,无输出结果

D)-1

60.在C语言中,不正确的血类型的常数是(A)o

A)32768

B)0

C)037

D)OxAF

61.C语言提供的合法关键字是(D)o

A)swicth

B)chan

C)Case

D)default

62.表示“在使用x之前,先使x的值加1”的正确方式是(A)o

A)++x

B)x-H-

C)+x

D)+x+

63.设x的值为5,则表达式(++x)+(++x)+(++x)的值是(D)o

A)24

B)20

C)15

D)21

64.在C语言中,合法的字符常量是(B)。

A)'084'

B)\x43'(十六进制)

C)匕b'

D)“\0”

65.若已定义x和y为double类型,则表达式:x=l,y=x+3/2的值是(C)。

A)1

B)2

C)2.0

D)2.6

66.若t为double类型,表达式t=l,t+5,t++的值是(D

A)1

B)6.0

C)2.0

D)1.0

67.若有以下定义和语句,则输出结果是(B)。

charcl=tb,,c2=te,;

printf(4t%d,%c\n,,,c2-cl,c2-,a,+,A,);

A)2,M

B)3,E

C)2,E

D)输出项与对应的格式控制不一致,输出结果不确定

68.设有如下的变量定义:

inti=8,a,b;

doublex=1.42,y=5.2;

则以下符合C语言语法的表达式是(A)o

A)a+=a・=(b=4)*(a=3)

B)x%(-3)

C)a=a*3=2

D)y=float(i)

69.若有以下定义和语句:

intu=010,v=0x10,w=10;

printf(€4%d,%d,%d\n,\u,v,w);()

则输出结果是(A)。

A)8,16,10

B)10,10,10

C)8,8,10

D)8,10,10

二、填空题

1.若x和a均是int型变量,则计算表达式⑴后的x值为丝,计算表达式⑵后的x值

为4o

(1)x=(a=4,6*2)

(2)x=a=4,6*2

2.若a是int型变量,则表达式(a=4*5,a*2),a+6的值为26»

3.若b是int型变量,则表达式b=25/3%3的值为2«

4.若s是int型变量,且s=6则下面表达式s%2+(s+l)%2的值为1。

5.若a,b和c均是int型变量,则计算表达式a=(b=4)+(c=2)后,a值为b值为当c

值为2o

6.若x和n均是int型变量,且x和n的初值均为5,则计算表达式x+=n++后x的值

为卫,n的值为6o

7.若有定义:intb=7;floata=2.5,c=4.7;则表达式a+(int)(b/3*(int)(a+c)/2)%4的值为5.5。

8.若有定义:inta=2,b=3;floatx=3.5,y=2.5;则表达式(float)(a+

B)/2+(int)x%(int)y的值为3.5。

9.若有定义:intx=3,y=2;floata=2.5,b=3.5;则表达式(x+y)%2+(int)a/(int)b的值为

10.若x和n均是整型变量,且x的初值为12,n的初值为5,则计算表达式x%=(n%=2)

后x的值为0«

11.以下程序的输出结果是必

main()

{unsignedshorta=65536;intb;

printf("%d\n",b=a);}

12.请写出数学式a/bc的C语言表达式a/(b*c)。

13.设a、b、c为整型数,且a=2、b=3、c=4,则执行完语句a*=16+(b++)-(++c)后,a

的值是28»

—单项选择题

1.printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列,如果字符串

长度大于5,则输出按方式(B)。

A)从左起输出该字符串,右补空格

B)按原字符长从左向右全部输出

C)右对齐输出该字串,左补空格

D)输出错误信息

2.已有定义inta=-2;和输出语句printf("%8x”,a);以下正确的叙述是(D)»

A)整型变量的输出形式只有%d一种

B)%x是格式符的一种,它可以适用于任何一种类型的数据

C)%x是格式符的•种,其变量的值按十六进制输出,但%8x是错误的

D)%8x不是错误的格式符,其中数字8规定了输出字段的宽度

3.若x,y均定义成int型,z定义为double型,以下不合法的scanf函数调用语句是(D)。

A)scanf("%d%x,%le",&x,&y,&z);

B)scanf(“%2d*%d,%lf;&x,&y,&z);

C)scanf("%x%*d%o",&x,&y);

D)scanfT%x%o%6.2f;&x,&y,&z);(双精度型用%le,或者%If)

4.以下程序的输出结果是(D)。

main()

{intk=17;

printf("%d,%o,%x\n",k,k.k);

I

A)17,021,0x11

B)17,17,17

B)17,0x11,021

D)17,21,11

5.下列程序的运行结果是(B)o

#include<stdio.h>

main()

{inta=2,c=5;

printf("a=%d,b=%d\n",a,c);

A)a=%2,b=%5

B)a=2,b=5

C)a=d,b=d

D)a=2,c=5

6.语句printf(”a\brethNy\\\bou\n)的输出结果是(C)。(说明AS是退格符)

A)a\breVhiVy\\\bou

B)a\bre\,hi\,y\bou

C)re'hi'you

D)abre'hi'y'bou

7.x、y、z被定义为int型变量,若从键盘给x、y、z输入数据,正确的输入语句是(B)。

A)INPUTx、y、z;

B)scanf(H%d%d%du,&x,&y,&z);

C)scanf(n%d%d%dn,x,y,z);

D)read(n%d%d%d",&x,&y,&z);

8.若变量已正确说明为float类型,要通过语句scanf("%f%f%f",&a,&b,&c);给a赋于

10.0,b赋予22.0,c赋予33.0,不正确的输入形式是(B):

A)10v回车〉

B)10.0,22.0,33.0〈回车〉

22c回车〉

33〈回车〉

C)10.0<回车>

D)1022c回车〉

22.033.0<回车>33〈回车>

9.以下程序的输出结果是(A)。

main()

(

intn;

(n=6*4,n+6),n*2;

printf("n=%d\n”,n);

)

A)24

B)12

C)26

D)20

10.以下程序的输出结果是(B)o

main()

{

intx=2,y,z;

x*=3+l;

printf("%dj,x++);

x+=y=z=5;

printf("%d1,x);

x=y=z;

printfft%d\n,,,x);

)

A)8,14,1

B)8,14,5

C)8,13,5

D说14,5

11.下面程序的输出结果是(C)o

main()

intx,y,z;

x=O;y=z=-l;

x+=-z・-y;{(-z-)-y)

printf("x=%d\n”,x);

)

A)x=4

B)x=0

C)x=2

D)x=3

12.设x为int型变量,贝I」执行语句x=10;x+=x・=x・x;后,x的值为(B)。

A)10

B)20

C)40

D)30

13.只能向终端输出一个字符的函数是(B)。

A)printf函数

B)putchar函数

C)getchar函数

D)scanf函数

14.下列程序执行后的输出结果是(小数点后只写一位)(A)o

main()

{doubled;floatf;long1;inti;

i=f=l=d=20/3;

printf(M%d%ld%f%f\n",i,l,f,d);

}

A)666.06.0

B)666.76.7

C)666.06.7

D)666.76.0

15.在下列叙述中,错误的一条是(C)。

A)printf函数可以向终端输出若干个任意类型的数据

B)putchar函数只能向终端输出字符,而且只能是一个字符

C)getchar函数只能用来输入字符,但字符的个数不限

D)scanf函数可以用来输入任何类型的多个数据

16.以下程序的输出结果为(B)。

main()

{

charcl=4a\c2=tb\c3=<c,;

printR“a%cb%c\tc%c\n”,c1,c2,c3);

)

A)abcabcabc

B)aabbcc

C)abc

D)aaaabb

17.若输入12345和abc,以下程序的输出结果是(B)。

main()

{

inta;

charch;

scanf(tt%3d%3c,\&a,&ch);

printf(44%d,%c",a,ch);

}

A)123,abc

B)123,4

C)123,a

D)12345,abc

18.以下程序的输出结果是(D)o

main()

{

unsignedxl;

intb=-1;

xl=b;

printf(u%u,,,xl);

}

A)%u

B)-l

C)%u-l

D)65535

19.在printf函数中用来输出十六进制无符号整数的格式字符是(B)。

A)d格式符

B)x格式符

C)u格式符

D)o格式符

20.设a=12、b=12345,执行语句printf(“%4d,%4cT,a,b)的输出结果为(B)。

A)12,123

B)12,12345

C)12,1234

D)12,123456

21.以下程序的输出结果是(C)。

#include<stdio.h>

#include<math.h>

main()

{

inta=l,b=4,c=2;

floatx=10.5,y=4.0,z;

z=(a+b)/c+sqrt((double)y)*1.2/c+x;

printfC%i\n,\z);

A)14.000000

B)15.400000

C)13.700000

D)14.900000

22.以下程序的输出结果是(D)o

main()

{

inta=2,c=5;

printf("a=%%d,b=%%d\rT,a,c);

A)a=%2,b=%5

B)a=%2,c=%5

C)a=%%d,b=%%d

D)a=%d,b=%d

23.请读程序:

main()

(

inta;

floatb,c;

scanf(4t%2d%3f%4f\&a,&b,&c);

printf(4€\na=%d,b=%f,c=%f\n,\a,b,c);

)

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

(C)。

A)a=98,b=765,c=4321

B)a=10,b=432,c=8765

C)a=98,b=765.000000,c=4321.000000

D)a=98,b=765.0,c=4321.0

24.若有定义:intx,y;chara,b,c;并有以下输入数据(此处<CR>代表回车,U代表空

格):

1U2<CR>

AUBUC<CR>

则能给x赋整数1,给y赋整数2,给a赋字符A,给b赋字符B,给c赋字符C的正

确程序段是(D)o

A)scanf(4€x=%d,y=%d",&x,&y);a=getchar();b=getchar();c=getchar();

B)scanf("%d%d",&x,&y);a=getchar();b=getchar();c=getchar();

C)scanf("%d%d%c%c%c”,&x,&y,&a,&b,&c);

D)scanf("%d%d%c%c%c%c%c%c”,&x,&y,&a,&a,&b,&b,&c,&c);

25.下列可作为C语言赋值语句的是(C)o

A)x=3,y=5;

B)a=b=6

C)i・・;

D)y=int(x);

26.设i是int型变量,f是float型变量,用下面的语句给这两个变量输入值:

scanf("i=%d,&i,&f);

为了把100和765.12分别赋给i和f,则正确的输入为(B)。

A)100<空格>765.12<回车〉

B)100,765.12〈回车〉

C)100〈回车>765.12〈回车)

D)x=100〈回车>y=765.12v回车〉

27.以下叙述中正确的是(D)。

A)输入项可以是一个实型常量,例如:scanf("%F,3.5);

B)只有格式控制,没有输入项,也能正确输入数据到内存,例如:scanf("a=%d,b=%d");

C)当输入一个实型数据时,格式控制部分可以规定小数点后的位数,例如:

scanf(tt%4.2f,,&f);

D)当输入数据时,必须指明变量地址,例如:scanf("%『,&f);

28.设x和y均为int型变量,则以下语句:x+=y;y=x-y;x-=y;的功能是(D)。

A)把x和y按从小到大排序

B)把x和y按从大到小排序

C)无确定结果

D)交换x和y中的值

二填空题

1.卜一面程序的运行结果是i:dcc=-4,oct=17774,hcx=ffffc,unsigncd=65532。

main()

{

shorti;

i=-4;

printf("\ni:dec=%d,oct=%o,hex=%x,unsigned=%u\n”,i,i,i,i);

}

2.若想通过以下输入语句使a=5.0,b=4,c=3,则输入数据的形式应该是5.0,4,c=3。

intb>c;floata;

scanf("%f,%d,c=%d",&a,&b,&c);

3.下列程序的输出结果是16.00,请填空。

main()

{inta=9,b=2;

floatx=6.6,y=l.l,z;

z=a/2+b*x/y+l/2;(1/2=0,a/2=4)

printf("%5.2f\n",z);

}

4.在printf格式字符中,只能输出一个字符的格式字符是%c;用于输出字符串的格式

字符是%s;以小数形式输出实数的格式字符是%f;以标准指数形式输出实数的格式字符

是%e。

三编程题

1.若a=3,b=4,c=5,x=1.2,y=2.4,z=36,u=51274,n=128765,cl=,a\c2='b'。想得到以下

的输出格式和结果,请写出完整的程序(包括定义变量类型和设计输出)。

要求输出的结果如下:

a=〈空格>3〈空格x空格,b=v空格,4V空格><空格,c=v空格>5

x=1.200000,y=2.400000,z=-3.600000

x+y=v空格>3.60〈空格>v空格>y+z=・1.20〈空格>v空格>z+x=-2.40

u=v空格>51274V空格,v空格>n=<空格>v空格,v空格>128756

cl=a〈空格>or<空格>97(ASCII)

c2=B(空格>or<空格>98(ASCH)

2.输入一个华氏温度,要求输出摄氏温度。公式为C=5/9(F・32)

输出要有文字说明,取2位小数。

3.编程序,用getchar函数读入两个字符给cl、c2,然后分别用putchar函数和printf

函数输出这两个字符。

三编程题参考答案

1.解:

main()

{

inta=3,b=4,c=5;

longintu=51274,n=128765;

floatx=1.2,y=2.4,z=-3.6;

charcl='a',c2=,b,;

printf(“\n”);

printf("a=%2db=%2dc=%2d\n,,,a,b,c);

printf(44x=%8.6f,y=%8.6f,c=%9.6f\n,,,x,y,z);

printf("x+y=%5.2fy+z=%5.2fz+x=%5.2f\n”,x+y,y+z,z+x);

printf(4tu=%6ldn=%91d\n,,,u,n);

printfC4cl=%cor%d(ASCII)\n,,,cl,cl);

printff4c2=%cor%d(ASCH)\n”,c2,c2);

)

2.解:

main()

(

floatc,f;

printf(“请输入一个华氏温度:\n");

scanR"%P,&f);

c=(5.0/9.0)*(f-32);

printfT摄氏温度为:%.2f\n,,,c);

}

3.解:

#include<stdio.h>

main()

{

charcl,c2;

printf(“请输入两个字符给cl和c2:\n");

cl=getchar();

c2=getchar();

printf(“用putchar函数输出结果为:\n”);

putchar(c1);

putchar(c2);

printf(44\n用printf函数输出结果为:\n”);

printf("%c,%c\n,,,cl,c2);

}

一单项选择题

1.逻辑运算符两侧运算对象的数据类型是(D)o

A)只能是0或1

B)只能是0或非0正数

C)只能是整型或字符型数据

D)可以是任何类型的数据

2.已知x=43,ch=A,y=0;则表达式(x>=y&&ch〈B&&!y)的值是(C)。

A)0

B)语法错

C)1

D)“假”

3.已知intx=10,y=20,z=30;以下语句执行后x,y,z的值是(B)。

if(x>y)

z=x;x=y;y=z;

A)x=10,y=20,z=30

B)x=20,y=30,z=30

C)x=20,y=30,z=10

D)x=20,y=30,z=20

4.执行下列语句后a的值为(C),b的值为()o

inta,b,c;

a=b=c=l;

++a||++b&&-H-C;

A)错误1

B)22

C)21

D)11

5.若希望当A的值为奇数时,表达式的值为“真”,A的值为偶数时,表达式的值为“假'

则以下不能满足要求的表达式是(C)。

A)A%2=1

B)!(A%2==0)

C)!(A%2)

D)A%2

6.设有:inta=l,b=2,c=3,d=4,m=2,n=2;执行(m=a>b)&&(n=c>D)后n的值是(B)。

A)0

B)2

C)3

D)4

7.判断char型变量cl是否为小写字母的正确表达式是(D)。

A)'a'v=clv='z'

B)(cl>=a)&&(cl<=z)

C)('a'>=cl)||('z'v=cl)

D)(cl>=ta,)&&(cl<=€z,)

8.以下不正确的if语句形式是(C)o

A)if(x>y&&x!=y);

B)if(x==y)x+=y;

C)if(x!=y)scanfC%d”,&x)elsescanfC%d”,&y)

D)if(x<y){x++;y++;}

9.请阅读以下程序:

main()

{

inta=5,b=0,c=0;

if(a=b+C)prin氓

elseprintf("$$$\rT);

)

以上程序(D)o

A)有语法错不能通过编译

B)可以通过编译但不能通过连接

C)输出***

D)输出$$$

10.当a=l,b=3,c=5,d=4时,执行完下面一段程序后x的值是(B)。

if(a<b)

if(c<D)x=l;

else

if(a<C)

if(b<D)x=2;

elsex=3;

elsex=6;

elsex=7;

A)1

B)2

C)3

D)6

11.以下程序的输出结果是(C)o

inain()

{inta=l00,x=10,y=20,ok1=5,ok2=0;

if(x〈y)

if(y!=10)

if(!okl)

a=l;

else

if(ok2)a=10;

a=-l;

printfC%d\n”,a);

)

A)1

B)10

C)-l

D)值不确定

12.以下程序的输出结果是(B)。

main()

{intx=2,y=-1,z=2;

if(x〈y)

if(y<0)z=0;

elsez+=l;

printfT%d\n”,z);

}

A)3

B)2

C)1

D)0

13.为了避免在嵌套的条件语句if-else中产生二义性,C语言规定:else子句总是与

B)配对。

A)缩排位置相同的if

B)其之前最近的if

C)其之后最近的if

D)同一行上的

14.若有条件表达式(exp)?a++:b-,则以下表达式中能完全等价于表达式(exp)的是

B)。

A)(exp=0)

B)(exp!=0)

C)(exp=l)

D)(exp!=l)

15.若运行时给变量x输入12,则以下程序的运行结果是(A)。

main()

{intx,y;

scanf(“%d”,&x);

y=x>12?x+10:x-12;

printR"%d\n”,y);

}

A)0

B)22

C)12

D)10

16.语句:printff%d”,(a=2)&&(b=-2));的输出结果是(D)。

A)无输出

B)结果不确定

0-1

D)1

17.当c的值不为0时,在下列选项中能正确将c的值赋给变量a、b的是(C)o

A)c=b=a;

B)(a=C)||(b=C);

C)(a=C)&&(b=C);

D)a=c=b;

18.能正确表示a和b同时为正或同时为负的表达式是(D)。

A)(a>=0||b>=0)&&(a<0||b<0)

B)(a>=0&&b>=0)&&(a<0&&b<0)

C)(a+b>0)&&(a+b<=0)D)a*b>0

19.能正确表示逻辑关系:“aN10或aSO”的C语言表达式是(D)。

A)a>=10ora<=0B)a>=0|a<=10

C)a>=10&&a<=0

D)a>=10||a<=0

20.有如下程序段

inta=14,b=15,x;

charc='A';

x=(a&&b)&&(c<4B,);

执行该程序段后,x的值为(D)。

A)ture

B)false

C)0

D)1

21.以下程序的输出结果是(C)o

A)-l1

B)01

C)10

D)00

main()

{inta=-l,b=l,k;

if((+4-a<0)&&!(b-<=0))

printf("%d%d\n*\a,b);

else

printf("%d%d\nM,b,a);

}

22.与y=(x>0?l:xv0?-l:0);的功能相同的if语句是(A)。

A)if(x>0)y=l;

B)if(x)

elseififx<0)y=-l;if{x>O)y=l;

elsey=0;elseif(x<O)y=-l;

elsey=0;

C)y=-lD)y=0;

if(x)if(x>=0)

if(x>0)y=l;if(x>O)y=l;

elseififx=O)y=O;elsey="l;

elsey="l;

23.阅读以下程序:

main()

{intx;

scanf(n%dH,&x);

if(x-<5)printf(n%dn,x);

elseprintf(M%dn,x-H-);

}

程序运行后,如果从键盘上输人5,则输出结果是(B)。

A)3

B)4

C)5

D)6

24.假定w、x^y、z^m均为int型变量,有如下程序段:

w=l;x=2;y=3;z=4;

m=(w<x)?w:x;m=(m<y)?m:y;m=(m<z)?m:z;

则该程序运行后,m的值是(D)。

A)4

B)3

C)2

D)1

25.有如下程序

main()

{floatx=2.0,y;

if(x<0.0)y=0.0;

elseif(x<10.0)y=1.0/x;

elsey=1.0;

printf(4€%f\n,,,y);

)

该程序的输出结果是(C)。

A)0.000000

B)0.250000

C)0.500000

D)1.000000

26.有如下程序

main()

{inta=2,b=-l,c=2;

if(a)if(b<0)c=0;

elsec";

printf("%d\n”,C);

)

该程序的输出结果是(A)o

A)0

B)1

C)2

D)3

27.若有定义:floatw;inta,b;则合法的switch语句是(C)。

A)switch(w)

Bswitch(x)

{case1.0:printR”*\n");{case1,2:printf(u*\n");

case2.0:printf("**\n”);case3:printf("**\n");

}无default语句}

C)switch(b)

D)switch(a+b);

{case1:printfC,*\nn);{case1:printf(M*\nn);

default:printf(M\n");case2:printff**\n”);

case1+2:printf(u**\n");default:printf("\nn);

}}

28.若a、b、cl、c2、x、y均是整型变量,正确的switch语句是(D)。

A)swich(a+b);

B)switch(a*a+b*b)

{case1:y=a+b;break;{case3:

case0:y=a-b;break;casel:y=a+b;break;

}case3:y=b-a;break;

}

C)switcha

D)switch(a-b)

{casecl:y=a-b;break;{default:y=a*b;break;

casec2:x=a*d;break;case3:case4:x=a+b;break;

default:x=a+b;case10:case11:y=a-b;break;

}}

29.有如下程序

main()

{intx=l,a=0,b=0;

switch(x)

{

case0:b++;

case1:a++;

case2:a++;b~H~;

}

printf(44a=%d,b=%d\n,,,a,b);

}

该程序的输出结果是(A)o

A)a=2,b=l

B)a=l,b=l

C)a=l,b=0

D)a=2,b=2

30.当输入19、2、21时,以下程序的输出结果是(A)o

main()

{inta,b,c,max;

printff'pleaseinputthreenumbersa,b,c:\n^^);

scanf("%d,%d,%d”,&a,&b,&C);

max=a;

if(max<b)

max=b;

if(max<C)

max=c;

printfV'maxis:%d\n”,max);

)

A)maxis:21

B)maxis:19

C)maxis:42

D)maxis:40

31.若输入B,以下程序的输出结果是(C)。

main()

{chargrade;

scanf("%c”,&grade);

switch(grade)

(

case'A':printR”>=85.”);

case'B':

case'C':printfC>=60.");

case,D,:printfTv60.");

default:printfC'error.");

|

}

A)>=85.

B)>=60.

C)>=60.<60.error.

D)error.

32.当执行以下语句后的输出结果是(D)。

intx=3,y=0;

printf("%d,%d»,-l>x>-10&&l<x<10,-l>y>-10&&l<y<10);

A)03

B)30

C)33

D)11

33.执行x=5>l+2&&2||2*4<4・!0后,x的值为(C)。

A)-1

B)0

C)1

D)5

34.以下程序的输出结果为(C)。

main()

{inta,b,c,x,y,z;

a=10;b=2;

c=!(a%b);

x=!(a/b);

y=(a<b)&&(b>=0);

z=(a<b)||(b>=0);

printf(44c=%d,x=%d,y=%d,z=%d\n”,c,x,y,z);

)

A)c=O,x=l,y=l,z=O

B)c=5,x=0,y=l,z=0

C)c=l,x=O,y=O,z=l

D)c=10,x=2,y=0,z=l

35.下列运算符中,不属于关系运算符的是(D)。

A)<

B)>=

C)=

D)!

36.以下程序的输出结果是(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论