搜档网
当前位置:搜档网 › C语言选择题大全

C语言选择题大全

C语言选择题大全
C语言选择题大全

C语言选择题精选

*1、A

一个C程序的执行是从_____。

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

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

A)必须在最开始

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

C)可以任意

D)必须在最后

*5、B

一个C语言程序是由

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

C)若干过程组成 D)若干子程序组成

*6、A

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

A)char

B)char=int<1ong int<=float

C)char< int <1ong int=float=double

D)char=int =1ong int<=float

*7、C

若x,i,j和k都是int型变量,则执行下面表达式后x的值为

x=(i=4,j=16,k=32)

A)4 B)16 C)32 D)52

*8、B

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

A)7 B)8 C)6 D)2

*9、A

下列四组选项中,均不是C语言关键字的选项是

A)define B)getc C)include D)while

IF char scanf go

type printf case pow

*10、B

下面四个选项中,均是C语言关键字的选项是

A)auto B)switch C)signed D)if

enum typedef union struct

include continue scanf type

*11、C

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

A) A B)float C)b-a D)一123

P_0 1a0 goto temp do 一A int INT *12、C

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

A)必须为字母 B)必须为下划线

C)必须为字母或下划线 D)可以是字母,数字和下划线中任一种字符

*13、A

下面四个选项中,均是合法整型常量的选项是:

A)160 B)一0xcdf C)一01 D)一0x48a

一0xffff 01a 986, 012 2e5

011 0xe 0668 0x

*14、D

下面四个选项中,均是不合法的整型常量的选项是:

A)一一0f1 B)一0Xcdf C)一018 D)一0x48eg

一0xffff 017 999 一068

0011 12,456 5e2 03f

*15、B

下面四个选项中,均是不合法的浮点数的选项是

A) 160. B) 123 C)一.18 D)一e3

0.12 2e4.2 123e4 .234

e3 .e5 0.0 1e3 *16、B

下面四个选项中,均是合法浮点数的选项是

A) +le+1 B)-.60 C) 123e D)一e3

5e一9.4 12e-4 1.2e-.4 .8e4

03e2 一8e5 +2e一1 5.e一0 *17、A

下面四个选项中,均是合法转义字符的选项是

A)'\'' B)'\' C)'\018' D)'\\0'

'\\' '\017' '\f' '101'

'\n' '\"' 'xab' 'xlf'

*18、B

下面四个选项中,均是不合法的转义字符的选项是

A)'\'' B)'\1011' C)'\011' D)'\abc'

'\\' '\' '\f' '\101'

'\xf' '\a' '\}' 'xlf' *19、C

下面正确的字符常量是:

A)"a" B)'\\'' C)'W' D)''

*20、D

下面四个选项中,均是不正确的八进制数或十六进制数的选项是。

A) 016 B)oabc C)010 D) 0a12

0x8f 017 -0x11 7ff

018 0x8 0x16 -123

*21、C

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

A)一10 B)0abc C)0010 D) 0al2

0x8f 一017 一0x11 -0xl23

一011 0xc 0xf1 一0x8

*22、D

下面四个选项中、均是正确的数值常量或字符常量的选项是:

A)0.0 B)"a" C)'3' D)十001

0f 3.9E-2.5 011 0xabcd

8.9e lel 0xFFOO 2e2

'&' '\''' 0a 50.

*23、A

下面不正确的字符串常量是。

A)'abc' B)"12'12" C)"0" D)""

*24、C

若有代数式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*3

*25、A

已知各变量的类型说明如下:

int k,a,b;

unsigned long w= 5;

double x=1.42;

则以下不符合C语言语法的表达式是:

A) x%(一3) B) w+=-2

C) k=(a=2,b=3,a十b) D) a十= a一=(b=4)*(a=3)

*26、A

已知各变量的类型说明如下:

int i=8,k,a,b;

unsigned long w=5;

double x=1.42,y=5.2;

则以下符合C语言语法的表达式是:

A) a十=a一=(b= 4)*(a=3) B)a=a*3=2

C) x%(一3) D)y=f1oat(i)

*27、D

以下不正确的叙述是

A)在C程序中,逗号运算符的优先级最低

B)在C程序中,APH和aph是两个不同的变量

C)若a和b类型相同,在执行了赋值表达式a=b后b中的值将放人a中,而b中的值不变。

D)当从键盘输入数据时,对于整型变量只能输入整型数值,对于实型变量只能输入实型数值。

*28、D

以下正确的叙述是:

A)在C程序中,每行中只能写一条语句

B)若a是实型变量,C程序中允许赋值a=10,因此实型变量中允许存放整型数//存进去后就变成float型了

C)在C程序中,无论是整数还是实数,都能被准确无误地表示

D)在C程序中,%是只能用于整数运算的运算符

*29、B

以下符合C语言语法的赋值表达式是

A)d=9+e+f=d+9 B) d=9+e,f=d+9

C)d=9十e,e++,d十9 D)d=9十e++=d十7

*30、A

已知字母A的ASCII码为十进制数65,且c2为字符型,则执行语句c2='A'十'6'一'3';后,c2中的值为

A)D B)68 C)不确定的值 D)C

*31、D

在C语言中,要求运算数必须是整型的运算符是。

A) / B) ++ c) != D)%

*32、B 7 8 8

若以下变量均是整型,且num=sum=7;则执行表达式sum=num++,sum++,++num后sum的值为

A) 7 B 8 C) 9 D) 10

*33、D

在C语言中,int、char和short种类型数据在内存中所占用的字节数

A)由用户自己定义 B)均为2个字节

C)是任意的 D)由所用机器的机器字长决定

*34、A

若有说明语句:char c='\72'则变量c

A)包含1个字符 B)包含2个字符

C)包含3个字符 D)说明不合法,c的值不确定

*35、A

7 7.2 1 0

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

A)2·500000 B)2.7500OO C) 3.500000 D) 0.000000。

*36、B

sizeof(float)是:

A)一个双精度型表达式 B)一个整型表达式

C)一种函数调用 D)一个不合法的表达式

*37、C

设变量a是整型,f是实型,i是双精度型,则表达式10+'a'+i*f值的数据类型为

A)int B) float C) double D)不确定

*38、A

下面四个选项中,均是非法常量的选项是。

A)'as' B)'\\' c)-0xl8 D)0xabc

-0fff '\01' 01177 '\0'

'\0xa' 12, 56 0xf"a"

*39、D

在C语言中, char型数据在内存中的存储形式是:

A)补码 B)反码 C)原码 D)ASCII码

*40、B 1.256998

设变量n为f1oat类型,m为int类型,则以下能实现将n中的数值保留小数点后两位,第三位进行四舍五人运算的表达式是一一一。

A) n=(n*100+0.5)/100.0 B)m=n*100+0.5 ,n= m/100.0

C) n=n*100+0.5/100.0 D)n=(n/100+0.5)*100.0

*41、C

4 8

表达式18/4*sqrt(4.0)/8值的数据类型为:// sqrt函数返回值为double型

A) int B)float C)double D)不确定

*42、C

设C语言中,一个int型数据在内存中占2个字节,则unsigned int型数据的取值范围为:

A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647

*43、D

设有说明: char w; int x; f1oat y; double z;则表达式w* x+z一y值的数据类型为:

A)float B)char C)int D)double

*44、D

若有以下定义,则能使值为3的表达式是:

int k= 7,x =12;

A) x%=(k%= 5) B) x%=(k一k%5)

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

*45、C

设以下变量均为int类型,则值不等于7的表达式是

A) (x= y= 6, x+y,x+1) B)(x= y= 6,x+y,y+1)

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

*46、D

putchar函数可以向终端输出一个:

A)整型变量表达式值

B)实型变量值

C)字符串

D)字符或字符型变量值

*47、B

printf函数中用到格式符%5s ,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式

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

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

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

D)输出错误信息

*48、C

printf函数中用到格式符%5s ,其中数字5表示输出的字符串占用5列。如果字符串长度小于5,则输出按方式。

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

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

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

D)输出错误信息

*49、D

已有定义 int a=-2;和输出语句:printf("%8lx",a);以下正确的叙述是:

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

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

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

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

*50、D

若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);

*51、A

已有如下定义和输入语句 ,若要求a1,a2,c1,c2值分别为10,20,A和B,当从第一列开始输入数据时,正确的数据输入方式是

int a1,a2; char c1,c2;

scanf("%d%c%d%c",&a1,&c1,&a2,&c2);

A)10A 20B< CR> B)10 A 20 B

C)10A20 D)10A20 B

*52、B

已有定义int x; f1oat y;且执行scanf("%3d%f",&x,&y);语句,若从第一列开始输入数据12345 678(回车),则x 的值为A)12345 B)123 C) 45 D) 345

*53、B

已有定义int x; f1oat y;且执行scanf("%3d%f",&x,&y);语句,若从第一列开始输入数据12345 678(回车),则y 的值为: A)无定值 B)45.0000 C) 678.000000 D) 123.00000

*54、D

已有如下定义和输入语句,若要求a1,a2,c1,c2的值分别为10,20,A,B,当从第一列开始输入数据时,正确的数据输入方式是:

int a1,a2; char c1,c2;

scanf("%d%d",&a1,&a2);

scanf("%c%c",&c1,&c2);

A) 1020AB B)10 20AB

C)10 20 AB D)10 20AB

*55、D

已有程序段和输入数据的形式如下,程序中输入语句的正确形式应当为

main()

{int a;float f;

printf("\nInput number:");

输入语句

printf("\nf=%f,a= %d\n ,f,a);

}

Input number: 4.5 2

A )scanf("%d,%f",&a,&f); B)scanf("%f,%d",&f,&a)

C)scanf("%d%f",&a,&f); D)scanf("%f%d",&f,&a);

*56、B

根据定义和数据的输入方式,输入语句的正确形式为:

已有定义: float fl,f2;

数据的输入方式:4.52

3. 5

A)scanf("%f,%f",&f1,&f2); B)scanf("%f%f",&f1,&f2 );

C)scanf("%3.2f%2.1f",&f1,&f); D)scanf("%3.2f%2.1f",&f1,&f2);

*57、D

阅读以下程序,当输入数据的形式为25,13,10正确的输出结果为:

main()

{int x,y,z

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

printf("x+y+z=%d\n ,x+y+z);。

}

A)x +y+z=48 B)x +y+z=35

C)x +z=35 D)不确定值

*58、B

阅读下程序,若运行结果为如下形式 ,输入输出语句的正确内容是:

main()

{int x; float y;printf("enter x,y :")

输入语句输出语句

}

输入形式 enter x,y: 2 3.4

输出形式 x+y=5.40

A)scanf("%d,%f",&x,&y);printf("\nx+y= %4.2f",x+y);

B)scanf("%d%f",&x,&y );printf("\nx+y=%4.2f",x+y);

C)scanf("%d%f",&x,&y); printf("\nx+y=%6.lf",x+y);

D)scanf("%d%3.1f",&x,&y );printf("\nx十y=%4.2f",x+y);

*59、D

以下说法正确的是:

A)输入项可以为一实型常量,如scanf("%f",3.5);

B)只有格式控制,没有输入项,也能进行正确输入,如scanf("a=%d,b=%d");

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

如scanf("%4.2f",&f);

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

*60、A

根据下面的程序及数据的输入方式和输出形式,程序中输入语句的正确形式应该为:

main()

{char ch1 ,ch2 ,ch3;

输入语句

printf("%c%c%c",ch1,ch2,ch3);}

输入形式: A B C

输出形式: A B

A) scanf("%c%c%c",&ch1,&ch2,&ch3);

B) scanf("%c,%c,%c", &ch1,&ch2, &ch3);

C) scanf("%c %c %c",&ch1,&ch2,&ch3);

D) scanf("%c%c",&ch1,&ch2,&ch3);

*61、D

有输入语句: scanf("a= %d,b= %d,c=%d",&a,&b,&c);为使变量a的值为1,b为3,c为2,从键盘输入数据的正确形式应当是

A)132(回车)

B)1,3,2(回车)

C)a=1b=3c=2(回车)

D)a=1,b =3,c =2(回车)

*62、A

以下能正确地定义整型变量a,b和c 并为其赋初值5的语句是

A)int a=b= c= 5; B) int a,b, c= 5;

C)a= 5,b=5,c=5; D) a= b= c=5;

*63、A

已知ch是字符型变量,下面不正确的赋值语句是

A)ch='a+b'; B)ch='\0'; C)ch='7'+'9'; D) ch=5+9;

*64、B

已知ch是字符型变量,下面正确的赋值语句是

A) ch= '123'; B) ch= '\xff'; C) ch= '\08'; D) ch="\";

*65、B

若有以下定义,则正确的赋值语句是:

int a,b;float x;

A) a=1,b=2, B)b++; C) a= b= 5 D) b= int(x);

*66、B

设x 、y均为f1oat型变量,则以下不合法的赋值语句是

A)++x; B)y=(x%2)/10; C) x*=y+8; D)x=y=0;

*67、A

x,y,z均为int型变量,则执行语句x=(y=(z=10)+5)一5;后,x 、y 和之的值是:

A) x=10 B) x=10 C) x=10 D)x=10

y=15 y=10 y=10 y=5

z=10 z=10 z=15 z=10

*68、D

逻辑运算符两侧运算对象的数据类型一一一。

A)只能是0或1

B)只能是0或非0正数

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

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

*69、C

下关于运算符优先顺序的描述中正确的是一一一。

A)关系运算符< 算术运算符< 赋值运算符< 逻辑与运算符

B)逻辑运算符< 关系运算符< 算术运算符< 赋值运算符

C)赋值运算符< 逻辑与运算符< 关系运算符< 算术运算符

D)算术运算符< 关系运算符< 赋值运算符< 逻辑与运算符

*70、B

下列运算符中优先级最高的是一一一。

A)< B)十 C)&& D)!=

*71、C

能正确表示"当x 的取值在[1,10]和[200,210]范围内为真,否则为假"的表达式是一一一。

A) (x>=1) &&(x<=10) &&(x> = 200) &&(x<=210)

B) (x>=1) || (x<=10) ||(x>=200) ||(x<=210)

C) (x>=1) &&(x<=10)||(x>= 200) &&(x<=210)

D) (x > =1)||(x< =10) && (x> = 200)||(x<=210)

*72、C

表示图中坐标轴上阴影部分的正确表达式是:

/////||//////|

/////||//////|

-----------------------------> X

a b c

A)(X<=A)&&(X>=B)&&(X<=C)

B) (x< =a)||(b<=x<=c)

C)(x<=a)|| (x> =b) && (x<=c)

D)(x < =a)&&(b< = x < = c)

*73、C

判断char型变量ch是否为大写字母的正确表达式是一一一。

A)' A' <=ch<='z' B)(ch> = 'A')&(ch<=' z' )

C)(ch>=' A' )&&(ch<='z') D)(' A' < = ch)AND('z'> = ch)

*74、D

设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

*75、C

已知x =43,ch='A',y=0则表达式(x > = y && ch<'B'&&!Y) 的值是

A)0 B)语法错 C)1 D)"假"

*76、C

若希望当A的值为奇数时,表达式的值为"真",A的值为偶数表达式的值为"假"。则以下不能满足要求的表达式是:

A) A%2= =1 B)!(A%2 = =0) C)!(A%2) D) A%2

*77、B

设有 int a = 1,b=2,c =3, d =4, m=2, n=2;

执行(m= a>b)&&(n=c>d)后n的值为:

A)1 B )2 C)3 D)4

*78、 D

判断char型变量c1是否为小写字母正确表达式为:

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

C)(' a' >=cl)||(' z' < = cl) D)(c1>='a')&&(cl<='z')

*79、B

以下程序的运行结果是:

#i nclude "stdio.h"

main() ,, \

{int a,b,d= 241;

a=d/100 % 9

b= (一1)&&(一1);

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

}

A)6,1 B)2,1 C) 6,0 D)2,0

*80、C

执行以下语句后a的值为:

int a,b,c;

a= b= c= 1;

++a||++b&&++c

A)错误 B) 0 C) 2 D) 1

*81、A

执行以下语句后b 的值为:

int a=5,b=6,w=1,x=2,y=3,z=4;

(a=w>x)&&(b=y>z);

A) 6 B) 0 C) 1 D) 4

*82、C

以下不正确的if语句形式是:

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

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

C)if(x != y)scanf("%d",&x )else scanf("%d",&y);

D)if(X

*83、A

下列运算符中优先级最低的是:

A)?: B)&& c)+ D) !=

*84、B

以下if语句语法正确的是一一一。

A)if(x>0)

printf("%f",x)

else printf("%f",- -x);

B) if (x>0)

{x=x+y;printf("%f",x);}

else printf("f",-x);

C) if(x>0)

{x=x+y; prinrf("%f",x);};

else printf("%f",-x);

D) if(x > 0)

{ x = x +y;printf("%f",x)}

else printf("%f",-x);

*85、D

请阅读以下程序:

main()

{int a=5,b=0,c=0;

if(a=b+c) printf("***\n ");

e1se printf("$$$\n");

以上程序 :

A 有语法错不能通过编译 B可以通过编译但不能通过连接

C 输出***

D 输出$$$

*86、C

以下程序的运行结果是 :

main()

{int m=5;

if(m++> 5) printf(" %d\n",m);

e1se printf("%d\n",m- - );

}

A)4 B)5 C)6 D)7

*87、B

当a=1,b=3,c=5,d=4 ,执行完下面一段程序后x 的值是 :

if(a

if(c

else

if(a

if(b

else x= 3;

else x=6;

else x=7;

A)1 B)2 C)3 D)6

*88、C

以下程序的输出结果是:

main()

{int a=100,x =10,y=20,okl=5,ok2=0;

if (x

if(y ! =10)

if(!okl) a=1;

else

if(ok2) a=10;

a=-1:

printf( "%d\n",a )

}

A) 1 B) 0 C)一1 D)值不确定

*89、B

以下程序的输出结果是:

main()

{int x= 2,y= 一1,z=2;

if (x

if(y<0) z= 0;

else z+ =1;

printf("%d\n",z);

}

A)3 B )2 C)1 D) 0

*90、B

为了避免在嵌套的条件语句If一else中产生二义性,C语言规定else子句总是与( )配对。

A)缩排位置相同的if B)其之前最近的if

C) 之后最近的if D)同一行上的if

*91、B

以下不正确的语句为:

A) if(x>y);

B) if (x= y) &&(x! = 0) x+= y;

C) if(x!= y)scanf("%d",&x); else scanf("%d",&y);

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

*92、B

请阅读以下程序:

#i nclude

main()

{float a,b

scanf("%f",&a);

if (a<10.0) b=1.0/x;

else if((a<0.5)&&(a!=2.0))b= 1.0/(a十2.0);

else if(a<10.0) b= 1.0/x ;

else b=10.0;

printf("%f\n",y);

}

若运行时输入2.0(回车),则上面程序的输出结果是:

A)0.000000 B)0.500000 C) 1. 000000 D) 0.250000

*93、B

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

A) (exp==0) B) (exp!=0)

C) (exp== 1) D) (exp!=1)

*94、A

若运行时给变量x 输入12,则以下程序的运行结果是:

main()

{int x,y;

scanf("%d",&x);

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

printf("%d\n",y);

}

A)0 B)22 C)12 0)10

*95、D

以下程序的运行结果是:

main()'

{int k= 4,a=3,b=2,c=;

printf("\n %d\n",k< a ? k:c

}

A)4 B )3 C)2 D)1

*96、B

执行以下程序段后、变量a,b,c的值分别是一。

int x=10,y=9;

int a,b,c;

a =(- -x = = y++)?- -x:++y ;

b = x ++;

c = y;

A )a=9,b= 9,c= 9

B )a=8,b=8,c=10

C )a=9,b= 10,c=9

D )a=1,b= 11,c=10

*97、A

若w,x,y,z,m均为int型变量,则执行下面语句后的m值是:

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

m=(w

m= (m

m=(m

A)1 B )2 C)3 D)4

*98、D

若w=1,X = 2,y= 3,z=4,则条件表达式w

A)4 B)3 C)2 D)1

*99、C

执行以下程序段后的输出结果是

int w=3, z=7,x =10;

printf("%d\n",x> 10? x+100:x 一10);

printf("%d\n",w++||z++ );

printf("%d\n",!w>z);

printf("%d\n",w&&z);

A)0 B) 1 C)0 D) 0 *100、C

设有程序段

int k=10;

while (k=0) k= k—1;

则下面描述中正确的是

A) while循环执行10次 B)循环是无限循环

C)循环体语句一次也不执行 D)循环体语句执行一次

*101、B

有以下程序段

int x=0,s=0;

while (! x!= 0) s+=++x;

printf("%d",s);

A)运行程序段后输出0 B)运行程序段后输出1

C)程序段中的控制表达式是非法的 D)程序段执行无限次*102、A

语句while(!E)中的表达式!E等价于:

A) E==0 B) E!=1 C) E!=0 D) E==1 *103、A

下面程序段的运行结果是

a=1;b= 2;c=2;

while(a

printf("%d,%d,%d",a,6,c);

A)1,2,0 B)2,1,0 C)1,2,1 D)2,1,1

*102、C

下面程序段的运行结果是:

x = y= 0;

while(x<15) y++,x + = ++y;

printf("%d,%d",y,x);

A) 20,7 B)6,12 C) 20,8 D)8,20 *103、C

【题5.6】下面程序段的运行结果是

if n=0;

while(n++<=2); printf("%d",n);

A) 2 B) 3 C) 4 D)有语法错

*104、B

设有程序段

t=0;

while (printf"*"妻"));

{t++;

if(t<3) break

}

面描述正确的是:

A)其中循环控制表达式与0等价 B)其中循环控制表达式与'0'等价

C)其中循环控制表达式是不合法的 D)以上说法部不对

*105、B

下面程序的功能是将从键盘输入的一对数,由小到大排序输出。当输入一对相等数时结束循环,请选择填空: #indude

main()

{int a,b,t;

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

while( 【1】 )

{if(a>b)

{t=a;a=b;b=t;}

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

scahf("%d%d",&a,&b);人

}

【1】 A} !a=b B} a!=b C} a= =b D} a=b

*106、C

下面程序的功能是从键盘输入的一组字符中统计出大写字母的个数m和小写字母的个数n,并输出m、n中的较大者,请选择填空: #indude "stdio.h"

main()

{int m=0,n=0;

char c; 1

while((【1】)!='\n')

{ if(c>='A' && C<='Z') m++ ;

if(c>='a' && c<='z') n++; }

printf("%d\n", m

1】 A) c=getchar() B) getchar() C)c=getchar() D) scanf("%c",c)

*107、C

下面程序的功能是将小写字母变成对应大写字母后的第二个字母。其中y变成A,z 变成B.请选择填空。

#i nclude "stdio. H"

main()

{ char c;

while((c=getchar())!='\n')

{if(c>= 'a'&& c<='z')

c - = 30;

if(c>'z' && c<='z'+ 2)

【2】; }

printf(" %c",c)

}

【2】A) c='B' B) c='A' C) c-=26 D) c=c+26

*108、B

下面程序的功能是在输入的一批正整数中求出最大者,输入0结束循环,请选择填空。

#include

main()

{int a,max= 0;

scanf("%d",&a)

while(【1】)

{if(max

scanf("%d",&a); )

printf("%d" ,max );}

【1】 A} a==o B}A C} !A = = 1D}!a

*109、C

下面程序的运行结果是。

#i nclude

main()

{ int num= 0;

while(num<= 2)

{num++

printf ("%d\n", num);}

}

A)1 B ) 1 C)1 D)1

2 2 2

3 3

4

*110、C

以下程序段

x= -1;

do

{x=x*x;}

while(!x);

A)是死循环 B)循环执行二次

C)循环执行一次 D)有语法错误

*111、C

以下描述中正确的是:

A)由于do一while循环中循环体语句只能是一条可执行语句,所以循环体内不能使用复合语句

B) do一while循环由do开始,用while结束,在while(表达式)后面不能写分号

C)在do一while循环体中,一定要有能使while后表达式值变为零("假")的操作

D)do一while循环中,根据情况可以省略while

*112、B

若有如下语句

int x=3;

do { printf(" %d\n",x -=2);} while(!(--x));

则上面程序段

A)输出的是 1 B)输出的是1和-2

C)输出的是3和0 D)是死循环

*113

下面程序的功能是计算正整数2345的各位数字平方和,请选择填空。

#i nclude

main()

{int n,sum=0;

n=2345

do{ sum=sum+(n%10)*n%10};

n=【2】;

}while(n);

printf("sum=%d",sum);}

【2】 A) n/1000 B)n/100 C) n/10 D) n%10

*114、B

下面程序是从键盘输入学号,然后输出学号中百位数字是3的学号,输入0时结束循环。请选择填空。

# include

main()

{1ong int num;

scanf("%ld",&num);

do { if( 【1】) printf("%ld",num);

scanf("%ld",&num);

}while(!num==0);}

【1】 A) num B) num>0==0 C)!num==0 D) !num!= 0

*115、B

下面程序的功能是把316表示为两个加数的和,使两个加数分别能被13和11整除。请选择填空。

#i nclude

main()

{int i=0,j,k;

do{ i++;k=316一13*i;}

while(【1】);j=k/11;

printf(" 316=13* %d十11*%d",i,j);

}

【1】A)k/11 B) k%11 C) k/11==0 D) k/11== 0

*116、D

下面程序的运行结果是:

#indude

main()

{int y=10;

do{y--;}

while(--y);

printf("%d\n",y--);

}

A)一1 B) 1 C)8 D) 0

*117、D

若运行以下程序时,从键盘输入ADescriptor(CR)表示回车),则下面程序的运行结果是: #include

main()

{ char c;

int v0=0.v1=0,v2=0;

do{

switch(c=getchar())

{case 'a':case 'A' :

case 'e':case ' E' :

case 'i':case 'I' :

case 'o':Case 'O' :

case 'u':case 'U' :vl+=1;

default:v0+=1;v2+=1 ;} ;

while(c!='\n');

printf("v0=%d,v1=%d,v2=%d\n",v0,v1,v2);

}

A}v0=7,v1=4,v2=7 B) v0=8,v 1=4,v2=8

C)v0= 11,v1=4,v2=11 D) v0=12,vl=4,v2=12

*118、B

下面程序的运行结果是:

#i nclude

main()

{int a==1,b=10;

do

{b-=a;a++;}while(b--<0);

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

} '

A)a=3,b=11 B )a=2,b=8 C)a=1, b=一1 D)a=4,b=9 *119、D

下面有关for循环的正确描述是:

A) for循环只能用于循环次数已经确定的情况

B) for循环是先执行循环体语句,后判断表达式

C) 在for循环中,不能用break语句跳出循环体

D) for循环的循环体语句中, 可以包含多条语句,但必须用花括号括起来*120、B

对for(表达式1;;表达式3)可理解为:

A) for(表达式1; 0;表达式3)

B) for(表达式1;1;表达式3)

C) for(表达式1;表达式1;表达式3)

D) for(表达式1;表达式3;表达式3)

*121、B

若i为整型变量,则以下循环执行次数是:

for (i=2;i==0;) printf("%d",i-- );

A)无限次 B) 0次 C) 1 次 D) 2次

*122、C

以下for循环的执行次数是:

for (x=0,y一0; (y=123)&&(x<4); x++);

A)是无限循环 B)循环次数不定 C)执行4次 D)执行3次

*123、A

以下不是无限循环的语句为:

A) for (y=0,x=1;x > ++y;x =i++) i=x ;

B) for (;; x++=i);

C) while (1){x ++;}

D) for(i=10; ;i--)sum+=i;

*124、C

下面程序段的运行结果是:

for (y= 1;y<10;) y=((x=3* y,x+1),x-1);

printf ("x=%d,y=%d",x,y);

A)x=27,y=27 B)x=12,y=13 C)x=15,y=14 D)x=y=27

*125、D

下面程序段的运行结果是

for(x=3;x<6;x++)printf((x %2)?("**%d"):(" ##%d\n"),x);

A)**3 B )##3 C)##3 D)**3##4

##4 **4 **4##5 **5

**5 ##5

*126、C

下列程序段不是死循环的是

A) int i=100; C) int k=0;

whiLe (1) do{++k;} while (k> =0) ;

{i=i%100+1;

if (i>100) break; D} int s=36;

} while (s);--s

B) for(;;);

*127、C

执行语句for(i=1;i++<4;);后变量i的值是

A)3 B )4 C)5 D)不定

*128、D

下面程序的功能是计算:至50中是7的倍数的数值之和,请选择填空。

#i nclude ·

main()

{int i,sum= 0;

for(i=1;i<=50;i++)

if([1]) sum+=i;

printf("%d",sum);

}

A) (int)(i/7)==i/7

B) (int)i/7==i/7

C) i%7= 0

D) i%7==0

*129、B

下面程序的功能是计算 1至10之间的奇数之和及偶数之和。请选择填空;

# include

main()

{int a,b,c,i;

a=c=0;

for(i=0;i<=10;i+=2)

{ a+=i;

[1];

c+=b;

}

printf("偶数之和=%d\n",a);

printf("奇数之和=%d\n",c-11),

}

[1] A )b=i-- B) b=i+1 C) b=i++ D)b=i-1

*130、B

下面程序的运行结果是:

#i nclude

main()

{int i;

for(i=1;i<=5;i++)

switch(i%5)

{case 0:printf("* ");break;

case 1 :printf("#");break;

default :printf("\n");

case 2 :printf("&");

}

A}#&&&* B} #& C} # D}#&

& &

& &

*

*131、D

下面程序的运行结果是:

#i nclude

main()

{ int x,i;

for(j-1;i<=100;i++)

{x=i;

if(++x%2==0)

if(++x%3==0)

if(++x%7==0)

printf("%d",x);

}

}

A)39 81 B)42 84 C)26 68 D) 28 70 *132、C

下面程序段的功能是计算1000!的末尾含有多少个零。请选择填空。

(提示:只要算出1000!中含有因数5的个数即可

for(k=0,i=5;i<=1000; i+=5)

while(【1】){k++; m=m/5;}

【1】A)m%5==0 B)m=m%5==0 C)m%5==0 D)m%5!=0

*133、D

下面程序的运行结果是:

#i nclude

main()

{int i,b,k=0;

for(i=1;i< =5;i++)

{b=i%2;

while(b-->=0) k++;

}

printf("%d,%d",k,b);

}

A)3,-1 B )8,-1 C)3,0 D)8,-2

*134、B

以下正确的描述是。

A)continue语句的作用是结束整个循环的执行

B)只能在循环体内和switch语句体内使用break语句

C)在循环体内使用break语句或continue语句的作用相同

D)从多层循环嵌套中退出时, 只能使用goto语句

*135、D

下面程序段:

for (t=1; t<=100;t++)

{scanf("%d",&x);

if(x<0) continue;

printf("%3d",t);}

A) 当x<0时整个循环结束

B) x>=0时什么也不输出

C) printf函数永远也不执行

D)最多允许输出100个非负整数

*136、C

下面程序段:

x=3;

do

{y=x--;

if(!y){ printf("x");continue;}

printf("#");

} while (1<=x<=2);

A)将输出## B)将输出##*

C)是死循环 D)含有不合法的控制表达式

*137、C

以下描述正确的是

A) goto语句只能用于退出多层循环

B) switch语句中不能出现continue语句

C) 只能用continue语句来终止本次循环

D) 在循环中break语句不能独立出现

*138、C

与下面程序段等价的是:

for(n=100;n<= 200; n++)

{if (n%3==0) continue;

printf("%4d",n);}

A) for(n=100;(n%3)&& n<=200;n++) printf("%4d",n);

B) for(n=100;(n%3)|| n<=200;n++) printf("%4d",n);

C) for(n=100;n<=200;n++)if(n%3!=0)printf("%4d",n)

D) for(n=100;n<=200; n++)

{if(n%3) printf("%4d",n);

else continue;

break;}

*139、B

下面程序的运行结果是:

#i nclude

{ int k=0;

char c='A';

do

{switch(c++)

{case 'A':k++;break;

case 'B':k--;

case 'C':k+=2;break;

case 'D':k=k%2;continue;

case 'E':k=k*10;breab;

default:k=k/3;}

k++;}

while(c<'G')

printf("k=%d",k);}

A)k=3 B)k=4 C)k=2 D)k=0

*140、B

若运行以下程序时,从键盘输入3.6,2.4,(表示回车),则下面程序的运行结果是: #indude

# include

main()

{float x,y,z;

scanf("%f%f",&x,&y);

z=x/y;

while(1)

{if(fabs(z)>1.0) {x=y;y=z;z=x/y;}

else break;}

printf("%f",y);}

A) 1.5 B)1.6 C) 2.0 D) 2.4

*141、B

下面程序的运行结果是:

#i nclude "stdio.h"

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;}

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

A) 7 B) 8 C)9 D) 10

*142、B

下面程序的运行结果是:

#i nclude "stdio.h"

main()

{int i;

for(i=1;i<=5;i++)

{if (i%2) printf("*");

else continue;

printf("#");

}

printf("#");}

A) *#*#$ B) #*#*#*$ C) *#*#$ D)#*#*$

*143、A

下面程序的运行结果是:

main()

{int i,j,a=0;

for (i=0;i<2;i++)

{ for (j=0;j<=4;j++)

{if (j%2) break;

a++;}

a++;}

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

}

A) 4 B) 5 C) 6 D) 7

*144、C

在c语言中,引用数组元素时,其数组下标的数据类型允许是__.

A)整型常量 B)整型表达式

C)整型常量或整型表达式 D)任何类型的表达式

*145、D

以下对一维整型数组a的正确说明是__。

A) int a(10); B)int n= 10,a[n];

c) int n; D) #define SIZE 10; scanf("%",&J1); int a[SIZE];

int a[n];

*146、D

若有说明:int a[10];则对a数组元素的正确引用是__。

A)a[10] B) a[3.5] C) a[5] D) a[10-10]

*147、A

在C语言中,一维数组的定义方式为:,类型说说明符数组名__。

A) [常量表达式] B) [整形表达式]

c)[ 整型常量]或[整型表达式] D)[整型常量]

*148、C

以下能对一维数组a进行正确初始化的语句是__。

A) int a[10]=(0,0,0,0,0) B)int a[10]={}

C) int a[]={0}; D) int a[10]={10*1};

*149、C

以下对二维数组a的正确说明是__。

A) int a[3][]; B) floatf a(3,4);

C) double a[1][4]; D) float a(3)(4);

*150、C

若有说明:int a[3][4]; 则对a数组元素的正确引用是__。

A) a[2][4] B) a[1,3] C) a[1+1][0] D) a(2)(1); *151、D

若有说明:int a[3][4];则对a数组元素的非法引用是__。

A) a[0][2*1] B) a[1][3] C)a[4-2][0] D)a[0][4]

*152、B

以下能对二维数组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}};

*153、C

以下不能对二维数组a进行正确初始化的语句是__。

A) int a[2][3]={0};

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}};

*154、D

若有说明: int a[3]「4」={0};则下面正确的叙述是

A」只有元素a[0][0]可得到初值0

B」此说明语句不正确:。

C」数组a中各元素都可得到初值,但其值不一定为0。

D」数组a中每个元素均可得到初值0

*155、D

若有说明:int a[]「4」={0,0};则下面不正确的叙述是__。

A)数组a的每个元素都可得到初值0

B)二维数组a的第一维大小为1

C)因为二维数组0中第二维大小的值除以初值个数的商为1,故数组a行

数为1

D)只有元素a[0]「0」和a[0]「1」可得初值0,其余元素均得不到初值0

*156、B

若有说明:int a[3]「4」;则数组a各元素

A」可在程序的运行阶段得到初值0

B」可在程序的编译阶段得到初值0

C」不能得到确定的初值

D」可在程序的编译或运行阶段得初值0

*157、C

以下各组选项中,均能正确定义二维实型数组a的选项是

A)float a[3][4]; B)float a(3,4);

float a[][4]; float a[3][4]; float a[3][]={{1},{0}}; float a[][]={{0},{0}}; C)float a[3][4]; D)float a[3][4];

static float a[][4]={{0},{0}}; float a[3][];

auto float a[][4]={{0},{0},{0}}; float a[][4]

*158、A

下面程序(每行程序前面的数字表示行号)

1 main()

2 {

3 int a[3]={3*0};

4 int i;

5 for(i=0;i<3;i++) scanf("%d",&a[i]);

6 for(i=1;i++) a[0]=a[0]+a[i]

7 printf("%d\n",a[0]);

A}没有错误 B)第3行有错误

C)第5行有错误 D)第7行没有错误

*159、C

下面程序一一一(每行程序前面的数字表示行号)。

1 main()

2 {

3 float a[10]={0.0};

4 int i

5 for(i=0;i<3;i++) scanf("%d",&a[1]);

6 for(i=0;i<10;i++) a[0]=a[0]+a[i];

7 printf("%d\n",a[0]);

8 }

A)没有错误 B)第3行有错误

C)第5行有错误 D)第7行有错误

*160、D

下面程序有错的行是

1 main()

2 {

3 int a[3]={1};

4 int i;

5 scanf("%d",&a);

6 for(i=1;i<3;i++) a[0]=a[0]+a[i];

7 printf("a[0]=%d\n",a[0]);

8 }

A)3 B)6 C)7 D)5

*161、D

下面程序(每行程序前面的数字表示行号)

1 main()

2 {

3 int a[3]={0};

4 int i;

5 for(i=0;i<3;i++)scanf("%d",&a[i]);

C语言选择题题库

C语言程序设计题库说明 一本题库适用对象 计算机应用技术计算机软件软件技术计算机网络技术与计算机控制技术等专业 二本题库包含有175道选择题 三本题库所有题目均附有答案

一、选择题 下列各题ABCD四个选项中,只有一个选项是正确的,请将正确选项涂在答题卡的相应位置上,答在试卷上不得分。 1、不合法的整数是()。 A)0x35 B)43.6 C)0532 D)-346 2、下列合法的字符常量是()。 A)“f” B)x C)65 D)‘\Xab’ 3、设有整型变量x,单精度变量y=,表达式x=float(y*3+((int)y%4))执行后,x的值为()。 A)17 B)17.500000 C) D) 4、在C语言中,负整数在内存中以()形式释放。 A)补码 B)BCD码 C)反码 D)十进制数 5、在C语言中,要求参加运算的数必须是整数的运算符是()。 A)/ B)!C)% D)= = 6、()是C语言中非法的数据类型关键字。 A)float B)singed C)integer D)Char

7、现已定义整形变量int i=1;执行循环语句while(i++<5);后i的值为()。 A)1 B)5 C)6 D)以上三个答案都不正确 8、下列语句的输出结果是()。 printf(“%f\n”,(float)(2+4)/2); A)有语法错误不能通过编译 B)3 C)D) 9、C语言中,整数-8在内存中的存储形式是()。 A)1111,1111,1111,1000 B)1000,0000,0000,1000 C)0000,0000,0000,1000 D)1111,1111,1111,0111 10、设C语言中,int类型数据占2个字节,则long类型数据占()个字节。 A)1 B)2 C)8 D)4 11、若变量a已说明为float类型,则能实现将a中的数值保留小数点后两位,第三位进行四舍五入运算的表达式是()。 A)a=(a*100+/ B)a=(a*100+/100 C)a=(int)(a*100+/ D)a=(a/100+*

C语言基本选择题及参考答案

C语言基本选择题及参考 答案 The pony was revised in January 2021

计算机程序设计基础(C语言) 单项选择练习题 一、基本概念 1.C语言程序是由C构成的。 A)一些可执行语言B)main函数C)函数D)包含文件中的第一个函数2.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 3.C语言程序从C开始执行。 A)程序中第一条可执行语句?B)程序中第一个函数 C)程序中的main函数?D)包含文件中的第一个函数 4.C语言程序从main()函数开始执行,所以这个函数要写在_D___。 A)程序文件的开始B)程序文件的最后 C)它所调用的函数的前面D)程序文件的任何位置 5、以下说法中正确的是(C)。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main()函数中定义

C、C语言程序总是从main()函数开始执行 D、C语言程序中的main()函数必须放在程序的开始部分 6.下列方法中错误的是(D)。 A.主函数可以分为两个部分:主函数说明部分和主函数体。 B.主函数可以调用任何非主函数的其它函数。 C.任何非主函数可以调用其它任何非主函数。 D.程序可以从任何非主函数开始执行。 7.下列说法错误的是:(B) A.C程序运行步骤是编辑、编译、连接、执行。 B.C语言的变量名必须用小写,常量用大写。 C.C语言的三种基本结构是顺序、选择、循环。 D.C程序一定由函数构成的。 8.下列关于C语言的说法错误的是(B)。 A)C程序的工作过程是编辑、编译、连接、运行 B)C语言不区分大小写。 C)C程序的三种基本结构是顺序、选择、循环

函数练习题(C语言)带答案

C语言函数练习题 一、选择题 1. 一个完整的C源程序是【】。 A)要由一个主函数或一个以上的非主函数构成 B)由一个且仅由一个主函数和零个以上的非主函数构成 C)要由一个主函数和一个以上的非主函数构成 D)由一个且只有一个主函数或多个非主函数构成 2. 以下关于函数的叙述中正确的是【】。 A)C语言程序将从源程序中第一个函数开始执行 B )可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行 C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束 D)m ain可作为用户标识符,用以定义任意一个函数 3. 以下关于函数的叙述中不正确的是【】。 A)C程序是函数的集合,包括标准库函数和用户自定义函数 B)在C语言程序中,被调用的函数必须在main函数中定义 C)在C语言程序中,函数的定义不能嵌套 D)在C语言程序中,函数的调用可以嵌套 4. 在一个C程序中,【】。 A)main函数必须出现在所有函数之前 B)main函数可以在任何地方出现 C)m ain函数必须出现在所有函数之后 D)m ain函数必须出现在固定位置 5. 若在C语言中未说明函数的类型,则系统默认该函数的数据类型是【】 A)float B)long C)int D)double 6. 以下关于函数叙述中,错误的是【】。 A)函数未被调用时,系统将不为形参分配内存单元 B)实参与形参的个数应相等,且实参与形参的类型必须对应一致 C)当形参是变量时,实参可以是常量、变量或表达式 D )形参可以是常量、变量或表达式 7. 若函数调用时参数为基本数据类型的变量,以下叙述正确的是【】。 A)实参与其对应的形参共占存储单元 B)只有当实参与其对应的形参同名时才共占存储单元 C)实参与对应的形参分别占用不同的存储单元 D)实参将数据传递给形参后,立即释放原先占用的存储单元 9. 函数调用时,当实参和形参都是简单变量时,他们之间数据传递的过程是【】。 A)实参将其地址传递给形参,并释放原先占用的存储单元 B)实参将其地址传递给形参,调用结束时形参再将其地址回传给实参 C)实参将其值传递给形参,调用结束时形参再将其值回传给实参

C语言题库_选择题(1)

本卷共有4道大 一、单项选择题(25道小题,共50分) 1、以下说法中正确的是(C)(2分) A、C语言程序总是从第一个的函数开始执行 B、在C语言程序中,要调用的函数必须在main()函数中定义 C、C语言程序总是从main()函数开始执行 D、C语言程序中的main()函数必须放在程序的开始部分 2、一个算法应该具有“确定性”等五个特性,下面对另外4个特性的描述中错误的是(B)(2分) A、有零个或多个输入 B、有零个或多个输出 C、有穷性 D、可行性 3、以下选项中,不合法常量的是(B)(2分) A、1.234e04 B、1.234e0.4 C、1.234e+4 D、1.234e0 4、C语言中最简单的数据类型包括(B)(2分) A、整型、实型、逻辑型 B、整型、实型、字符型 C、整型、字符型、逻辑型 D、整型、实型、逻辑型、字符型 5、能正确表示逻辑关系:“10≥=a≥=0”的C语言表达式是(D)(2分) A、10>=a>=0 B、a>=0 and a<=10 C、a>=0||a<=10 D、a>=0&&a<=10 6、设a和b均为double型变量,且a=5.5、b=2.5,则表达式(int)a+b/b的值是(D)(2分)A、6.500000B、6 C、5.500000 D、6.000000

7、x、y、z被定义为int型变量,若从键盘给x、y、z输入数据,正确的输入语句是(B)(2分) A、INPUT x、y、z; B、scanf("%d%d%d",&x,&y,&z); C、scanf("%d%d%d",x,y,z); D、read("%d%d%d",&x,&y,&z); 8、设x和y均为int型变量,则以下语句:x+=y;y=x-y;x-=y;的功能是(D)(2分)A、把x和y按从大到小排列B、把x和y按从小到大排列 C、无确定结果 D、交换x和y中的值 9、若有以下程序段:int c1=1,c2=2,c3;c3=1.0/c2*c1;则执行后,c3中的值是(A)(2分)A、0B、0.5 C、1 D、2 10、设char ch='A';则ch=(ch>='A'&&ch<='Z')?(ch+32):ch的值是(B)。(2分) A、A B、a C、Z D、z 11、执行程序段int a=-1,b=4,k;k=(++a<0)&&!(b-- <=0);printf(“%d %d %d\n”,k,a,b);后的输出结果是(D )。 (2分) A、1 0 4 B、1 0 3 C、0 0 3 D、0 0 4 12、设intx=1, y=1;表达式(!x||y--)的值是(B)。(2分) A、0B、1 C、2 D、-1 13、程序段intx=3;do{printf(“%d”,x-=2);}while(!(--x));的输出结果是(C)。(2分) A、1 B、30 C、1-2 D、死循环

C语言基础练习100题(含答案)

C语言基础练习100题(含答案) 欧阳学文 雷柳青编排 1、下面程序的输出是________ #include void main() { int k=11; printf("k=%d,k=%o,k=%x\n",k,k,k); } A) k=11,k=12,k=11 B) k=11,k=13,k=13 C) k=11,k=013,k=0xb D) k=11,k=13,k=b 2、在下列选项中,不正确的赋值语句是________. A) ++t; B) n1=(n2=(n3=0)); C) k=i=j; D) a=b+c=1; 3、下面合法的C语言字符常量是__________. A) '\t' B) "A" C) 65 D) A 4、字符(char)型数据在微机内存中的存储形式是____. A) 反码B) 补码C) EBCDIC码D) ASCII码 5、设int a=12,则执行完语句a+=a=a*a 后,a的值是________ A) 552 B) 264 C) 144 D) 264 6、执行下面程序中的输出语句后,输出结果是______. #include void main() {int a; printf("%d\n",(a=3*5,a*4,a+5)); } A) 65 B) 20 C) 15 D) 10 7、下面程序的输出是__________. #include void main() {int x=023; printf("%d\n",x); } A) 17 B) 18 C) 23 D) 24 8、下面程序的输出是___________. #include void main() {char ch1,ch2; ch1='A'+'5''3'; ch2='A'+'6''3'; printf("%d,%c\n",ch1,ch2); } A) 67,D B) B,C C) C,D D) 不确定的值 9、以下程序的输出结果是________. #include void main() { int x=10,y=10; printf("%d %d\n",x,y); } A) 10 10 B) 9 9 C) 9 10 D) 10 9 10、若x和y都是int型变量,x=100,y=200,且有下面的程序片段: printf("%d",(x,y)); 上面程序片段的输出结果是_______.

C语言程序设计期末考试选择题题库

第一章1、一个C程序可能出现的错误有(A)A,以上都包括 B,逻辑错误 C,运行错误 D,语法错误 2、C程序中一般可以包含几个函数(D) A.1个 B.多个 C.0个 D.至少一个 3.C语言属于程序设计语言的哪个类别(B) A.机器语言 B.高级语言 C.面向对象语言 D.汇编语言 4.以下关于C语言描述错误的是(B) A.一个C程序总是从main函数开始执行 B.一个C程序可以包含多个main函数 C.每个语句的最后必须有一个分号 D.C语言的注释符是以"/*"开始并以"*/"结束

5、在调试过程中,逻辑错误是指(C) A.所书写的语句,不符合C的语法。 B.在从obj生成exe文件的过程中,如果函数名书写错误,可能产生的错误。 C.程序的运行结果不符合题目要求。 D.在exe文件的执行过程中,产生运行异常。 第二章 1、16位的二进制数可以表示的整数的范围是(C) A.[-32768,32768] B.[-32767,32768] C.[-32768,32767] D.[-32767,32767] 2、C语言中的实型数据包括(A) A.float和double B.int和float C.float和char D.int和double 3、以下不合法的字符常量是(C) A.'2' B.'A' C.'ab'

4、在以下各组标识符中,均是合法的C语言标识符是(A) A.abc,A_4d,_student,xyz_abc B.auto,12-a,a_b,ab5.x C.A_4d,_student,xyz_abc,if D.abc,a_b,union,scan 5、若有定义:chara;intb;floatc;doubled; 则表达式a*b+d-c值的类型为(A) A.char B.float C.double D.int 6、类型修饰符unsigned不能修饰(D) A.char B.longint C.int D.float 7、若有定义:doublex=1,y; 执行语句,则y的值是(B) A,1 B,2.0

2020最新C语言考试题库及答案

精选考试类应用文档,如果您需要使用本文档,请点击下载,另外祝您生活愉快,工作顺利,万事如意! 精选考试类文档,如果需要,请下载,希望能帮助到你们! 2020最新C语言考试题库及答案

姓名成绩 温馨提示:同学们,经过培训学习,你一定积累了很多知识,现在请认真、仔细地完成这张试题吧。加油! 一单项选择题 1. 在C语言中,以 D 作为字符串结束标志 A)’\n’ B)’ ’ C) ’0’ D)’\0’ 2.下列数据中属于“字符串常量”的是( A )。 A.“a” B.{ABC} C.‘abc\0’ D.‘a’ 若干个字符构成字符串

在C语言中,用单引号标识字符;用双引号标识字符串 选项B,C,分别用{}和’’标识字符串 选项D,标识字符。 3、以下说法中正确的是( C )。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是( B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C )。 A.-a1 B.a[i] C.a2_i D.int t 6.下列C语言用户标识符中合法的是( B )。

A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是( C )。 A) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是( A )。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括(D )。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是 C 。 A)2.5 B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

C语言试题与答案

大学C语言考试题库 第1章 C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. A B. B C. D D. E (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 32 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系

C语言选择题#精选.

1 C语言程序由函数组成,以下说法正确的是( A ). A)主函数可以在其它函数之前,函数内不可以嵌套定义函数 B)主函数可以在其它函数之前,函数内可以嵌套定义函数 C)主函数必须在其它函数之前,函数内不可以嵌套定义函数 D)主函数必须在其它函数之前,函数内可以嵌套定义函数 2 以下说法中不正确的是( A )。 A) 主函数main中定义的变量在整个文件或程序中有效 B) 不同的函数中可以使用相同名字的变量 C) 形式参数是局部变量 D) 在一个函数内部,可以在复合语句中定义变量,这些变量只在本复合语句中有效 3 下面函数 f(double x) {printf(“%6d\n”,x);} 的类型为( C ). A) 实型B)void 类型C)int 类型D) A)、B)、C)均不正确 4 以下说法中正确的是( C ). A)C语言程序总是从第一个定义的函数开始执行 B)在C语言程序中,要调用的函数必须在main函数中定义 C)C语言程序总是从main函数开始执行

D)C语言程序中,main函数必须放在程序的开始部分 5 以下正确的函数定义是( C ). A) double fun(int x,int y); {int z; z=x+y; return z;} B) fun(int x,y) {int z; return z;} C) double fun(int x,int y) {double z; z=x+y; return z;} D) double fun( x, y) {int x,y; double z; z=x+y; return z;} 6 定义为void类型的函数,其含义是( A ). A)调用函数后,被调用的函数没有返回值 B)调用函数后,被调用的函数不返回 C)调用函数后,被调用的函数的返回值为任意的类型D)以上三种说法都是错误的 7 设有如下定义: int x=10,y=3,z ; 则语句

c语言练习题带答案)-绝对经典题目不看后悔

1单选题 1.(A)是构成C语言程序的基本单位。 A、函数 B、过程 C、子程序 D、子例程 2.C语言程序从C开始执行。 A) 程序中第一条可执行语句B) 程序中第一个函数 C) 程序中的main函数D) 包含文件中的第一个函数 3、以下说法中正确的是(C)。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是(B)。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C)。 A.-a1 B.a[i] C.a2_i D.int t 5~8题为相同类型题 考点:标识符的命名规则 (1)只能由字母、数字、下划线构成 (2)数字不能作为标识符的开头 (3)关键字不能作为标识符 选项A中的“-” ,选项B中“[”与“]”不满足(1);选项D中的int为关键字,不满足(3) 6.下列C语言用户标识符中合法的是(B)。 A)3ax B)x C)case D)-e2 E)union 选项A中的标识符以数字开头不满足(2);选项C,E均为为关键字,不满足(3);选项D中的“-”不满足(1); 7.下列四组选项中,正确的C语言标识符是(C)。 A)%x B)a+b C)a123 D)123 选项A中的“%” ,选项B中“+”不满足(1);选项D中的标识符以数字开头不满足(2) 8、下列四组字符串中都可以用作C语言程序中的标识符的是(A)。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 选项B中的“\”,”$” ,选项D中“>”,”#”,”.”,”-”不满足(1);选项C中的while为关键字,不满足(3) 9.C语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A)2.5 B)2 C)1 D)3 详见教材P52~53.

C语言单项选择题

单项选择题(本大题共20小题,每小题1分,共20分) 1.C++源程序文件扩展名为(A) A..cpp B..h C..1ib D..obj 5.对使用关键字new所开辟的动态存储空间,释放时必须使用(C)A.free B.create C.delete D.realse 6.从本质上看,引用是被引用变量的(B) A.拷贝 B.别名 C.复制 D.克隆 7.在函数调用时,如某一默认参数要指明一个特定值,则有(B) A.其之前所有参数都必须赋值B.其之后所有参数都必须赋值 C.其前、后所有参数都必须赋值D.其前、后所有参数都不必赋值 8.设存在函数int max(int,int)返回两参数中较大值,若求22,59,70三者中最大值,下列表达式不正确的是(C) A.int m=max(22,max(59,70));B.int m=max(max(22,59),70); C.int m=max(22,59,70);D.int m=max(59,max(22,70)); 9.设存在函数int min(int,int)返回两参数中较小值,若求15,26,47三者中最小值,下列表达式中错误的是(B) A.int m=min(min(15,26),min(15,47)); B.int m=min(15,26,47); C.int m=min(15,min(47,26)); D.int m=min(min(47,26),16); 13.函数int&min(int&,int&)返回参数中较小者,设有两整型变量int a=10;int b=15; 在执行语句min(a,b)--;之后,a,b值分别为(B) A.9,14 B.9,15 C.10,14 D.10,15 16.设函数void swap(int&,int&)将交换两形参的值,如两整型变量int a=10;int b=15;则执行swap(a,b)后,a、b值分别为(C) A.10,10 B.10,15 C.15,10 D.15,15

C语言选择题复习精选.

选择题复习 1.表达式“(a=4*5, b=a*2), b-a, a+=2”的值是(C)。 A.2 B.20 C.22 D.42 2.以下是一个自定义函数的头部,其中正确的是(C )。 A.int fun(int a[ ], b) B.int fun(int a[ ], int a) C.int fun(int*a, int b) D.int fun(char a[ ][ ], int b) 3.以下数组声明语句中正确的是(D )。 A.int n, a[n]; B.int a[ ]; C.int a[2][3]={{l},{2},{3}}; D.int a[ ][3]={{l},{2},{3}}; 4.已知在某C语言编译系统中表达式sizeof(int)的值是2,如果希望将常量-70 000正确地保存在一个变量a中,该变量声明语句应当是(B )。 A.int a; B.long int a; C.unsigned int a; D.unsigned int a; 5.以下声明语句中,用于声明一个行指针变量的是(C )。 A.int *p(int); B.int *p; C.int (*p)[3]; D.int (*p)(int); 6.在以下程序中,需要在fun函数中声明一个int型的变量,以下选项中(A )不能用做该变量的名字。 #include int y; main( ) { int a=1; fun(a); } int fun(int x) {_______; /*int型变量声明语句位置*/ … /*若干执行语句*/ } A.x B.y C.fabs D.fun 7.如有语句“int x,y=0,z,*p[3]; p[0]=&x; p[1]=&y; p[2]=&z;”,以下表达式中有语法错误的是(B )。 A.y++ B.p++ C.*++p[0] D.(*p[0])++ 8.设有声明语句“int a[3][3]={1,2,3,4,5,6,7,8,9};”,以下语句中除(D )外均能输出a[1][2]的值。 A.printf("%d ",*(*(a+1)+2)) B.printf("%d ",*(&a[2][0]-1)); C.printf("%d ",*(a[1]+2)); D.printf("%d ",*(a+1)[2]); 9.已知有声明语句int x=8,则下列表达式中,值为2的是(B )。 A.x+=x-=x B.x% = x-2 C.x>8?x=0:x++ D.x/= x + x 10.以下关于函数的叙述中正确的是(D )。 A.在函数体中可以直接引用另一个函数中声明为static类别的局部变量的值 B.在函数体中至少必须有一个return语句 C.在函数体中可以定义另一个函数 D.在函数体中可以调用函数自身 11.若有声明语句“int a[10], b[3][3];”,则以下对数组元素赋值的操作中,不会出现越界访问的是(D )。 A.a[-1]=0 B.a[10]=0 C.b[3][0]=0 D.b[0][2]=0

C语言试题-选择题及答案

C语言试题 ★第1 题: 阅读程序,选择程序的运行结果___A___。 #include main() { int x; x=try(5); printf(“%d\n”, x); } try(int n) { if(n>0) return(n*try(n-2)); else return(1); } A. 15 B. 120 C. 1 D. 前面3个答案均是错误的 第2 题: 在下列结论中,只有一个是正确的,它是___A___。 A. 递归函数中的形式参数是自动变量 B. 递归函数中的形式参数是外部变量 C. 递归函数中的形式参数是静态变量 D. 递归函数中的形式参数可以根据需要自己定义存储类型 ★第3 题: 阅读程序,选择程序的输出结果__A___。 #include f(int x, int y) { return(y-x); } main() { int (*g)(int,int); int a=5, b=6, c=2; g=f; c=(*g)(a,b); printf(“%d\n”, c); } A. 1 B. 2 C. 3 D. 前面3个答案均是错误的 第4 题: 阅读程序,选择程序的输出结果__D___。 #include

char *p=”abcdefghijklmnopq”; main() { while(*p++!=?e?) ; printf(“%c\n”, *p); } A. c B. d C. e D. f ★第6 题: 阅读程序,选择程序的输出结果___D___。 #include void prtv(int *x) { printf(”%d\n”, ++*x); } main() { int a=25; prtv(&a); } A. 23 B. 24 C. 25 D. 26 第7 题: 阅读程序,选择程序的输出结果___B___。 #include main() { static char a[ ]= ”language”, b[]=”program”; char *ptr1=a, *ptr2=b; int k; for(k=0; k<7; k++) if(*(ptr1+k)==*(ptr2+k)) printf(”%c”, *(ptr1+k)); } A. gae B. ga C. language D. 有语法错误 ★第8 题: 函数调用strcat(strcpy(str1, str2), str3)的功能是__C___。 A. 将串str1复制到串str2中,然后再连接到str3之后 B. 将串str1连接到串str2之后,再复制到str3之中 C. 将串str2复制到串str1中,然后再将串str3连接到串str1之后

c语言选择题及答案

1﹑以下选项中不合法的用户标识符是( C )。 A)_123 B)PP C)A$ D)Dim 2﹑C语言提供的合法数据关键字是( A )。 A)float B) Sagned C) Integer D) ing 3﹑判断char型变量c1是否为小写字母的正确表达式为( D )。 A) 'a'<=c1<='z' B) (c1>=A. &&(c1<='z') C) ('a'>=c1)||('z'<=c1) D) (c1>='a')&&(c1<='z') 4﹑C语言可执行程序开始执行点为( C ). A)程序中第一条可执行语句B) 程序中第一个函数 C)程序中的main函数D) 包含文件中的第一个函数 @ 5﹑以下说法中正确的是( C ). A)C语言程序总是从第一个定义的函数开始执行 B)在C语言程序中,要调用的函数必须在main函数中定义 C)C语言程序总是从main函数开始执行 D)C语言程序中,main函数必须放在程序的开始部分 6﹑设有定义:int a=1,b=2,c=3;,以下语句中执行效果与其它三个不同的是( C )。A)if(a>b) c=a,a=b,b=c; B)if(a>b) {c=a,a=b,b=c;} C)if(a>b) c=a;a=b;b=c; D)if(a>b) {c=a;a=b;b=c;} 7﹑若有说明和语句: int a=5,b; b=a++; 此处变量b的值是( C )。 A)7 B)6 C)5 D) 8﹑以下程序的输出结果是( D )。 ~ int x=10,y=10; printf("%d %d\n",x--,--y); A) 10 10 B) 9 9 C) 9 10 D) 10 9 9﹑C语言用( C )表示逻辑“真”值。 A)true B)t或y C)非零整数值D)整数0 10﹑指出下面正确的输入语句( B )。 A) scanf("a=b=%d",&a,&b) ; B) scanf("%d,%d",&a,&b) ; C) scanf("%c",c) ; D) scanf("% f%d\n",&f) ; 11﹑若x=5,y=3 则y*=x+5; y的值为(D )。 A)10 B)20 C)15 D)30 · 12﹑设整型变量n的值为2,执行语句"n+=n-=n*n;"后,n的值是( C )。 A)0 B)4 C)- 4 D)2 13﹑以下程序的运行结果是( D )。 void main() { int a=65; char c=’A’;

C语言试题选择题及答案

★第1 题: 阅读程序,选择程序的运行结果___A___。 #include main() { int x; x=try(5); printf(“%d\n”, x); } try(int n) { if(n>0) return(n*try(n-2)); else return(1); } A. 15 B. 120 C. 1 D. 前面3个答案均是错误的 第2 题: 在下列结论中,只有一个是正确的,它是___A___。 A. 递归函数中的形式参数是自动变量 B. 递归函数中的形式参数是外部变量 C. 递归函数中的形式参数是静态变量 D. 递归函数中的形式参数可以根据需要自己定义存储类型 ★第3 题: 阅读程序,选择程序的输出结果__A___。 #include f(int x, int y) { return(y-x); } main() { int (*g)(int,int); int a=5, b=6, c=2;

g=f; c=(*g)(a,b); printf(“%d\n”, c); } A. 1 B. 2 C. 3 D. 前面3个答案均是错误的 第4 题: 阅读程序,选择程序的输出结果__D___。#include char *p=”abcdefghijklmnopq”; main() { while(*p++!=’e’) ; printf(“%c\n”, *p); } A. c B. d C. e D. f ★第6 题: 阅读程序,选择程序的输出结果___D___。#include void prtv(int *x) { printf(”%d\n”, ++*x); } main() { int a=25; prtv(&a); } A. 23

(完整版)C语言程序设计选择题库及答案

单项选择题 导读:单项选择题要求从给出的四个备选答案中,选出一个最符合题意的答案。本类习题主要检查对C语言基本概念的掌握情况,读者可根据学习进度选做部分习题。在完成习题的过程中,不但要选出正确的答案,而且要清楚不正确的选项错在何处,以加深对概念的理解。对于掌握不准的问题, 应该通过上机实验来检验。 【1.1】以下不正确的C语言标识符是____。 A) int B) a_1_2 C) ab1exe D) _x 【1.2】以下是正确的C语言标识符是____。 A) #define B) _123 C) %d D) \n 【1.3】下列四组字符串中都可以用作C语言程序标识符的一组是。 ??? A) print B) i\am C) Pxq D) str_l ??? _3d one_half My->book Cpp ??? oodb start$it line# pow ??? aBc 3pai His.age while

【1.4】下面各选项组中,均是C语言关键字的组是。 A) auto,enum,include B) switch,typedef,continue C) signed,union,scanf D) if,struct,type 【1.5】下列不属于C语言关键字的是。A) default B) register C) enum D) external 【1.6】C语言程序从main()函数开始执行,所以这个函数要写在____。 A) 程序文件的开始B) 程序文件的最后 C) 它所调用的函数的前面D) 程序文件的任何位置 【1.7】下列关于C语言的叙述错误的是____ A) 大写字母和小写字母的意义相同 B) 不同类型的变量可以在一个表达式中 C) 在赋值表达式中等号(=)左边的变量和右边的值可以是不同类型 D) 同一个运算符号在不同的场合可以有不同的含义

C语言试题及答案06612

大学C语言考试题库 第1章C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. A B. B C. D D. E (2) 在C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于C 源程序是高级语言程序,因此一定要在TC 软件中输入 B. 由C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和0 个或多个函数组成 B. C 语言程序由主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有32 个关键字和9 种控制语句。

(2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系统软件又适合于编写应用程序。 (3) 每个源程序有且只有一个主函数,系统总是从该函数开始执行C语言程序。 (4) 在C 语言程序中允许出现的字符集是ASCII码字符集。 (5) C 语言的程序中有特殊含义的英语单词称为保留字。 (6) C 语言标识符的长度是前8 位有效。 (7) C 语言中,标识符的定义规则是以字母或下划线为开头。 (8) C 语言程序的注释可以出现在程序中的任何地方,它总是以/* 符号作为开始标记,以*/ 符号作为结束标记。 第2章数据类型运算符和表达式习题 1. 单项选择题 (1) 以下选项中,正确的C 语言整型常量是 D 。 A. 32L B. 510000 C. -1.00 D. 567 (2) 以下选项中, D 是不正确的C 语言字符型常量。 A. 'a' B. '\x41' C. '\101' D. "a" (3) 在C 语言中,字符型数据在计算机内存中,以字符的 C 形式存储。 A. 原码 B. 反码 C. ASCII 码 D. BCD码 (4) 字符串的结束标志是 C 。 A. 0 B. '0' C. '\0' D. "0" (5) 算术运算符、赋值运算符和关系运算符的运算优先级按从高到低依次为 B 。 A. 算术运算、赋值运算、关系运算 B. 算术运算、关系运算、赋值运算 C. 关系运算、赋值运算、算术运算 D. 关系运算、算术运算、赋值运算 (6) 逻辑运算符中,运算优先级按从高到低依次为 D 。 A. &&,!,|| B. ||,&&,! C. &&,||,! D. !,&&,|| (7) 表达式!x||a==b 等效于 D 。 A. !((x||a)==b) B. !(x||y)==b C. !(x||(a==b)) D. (!x)||(a==b) (8) 设整型变量m,n,a,b,c,d 均为1,执行(m=a>b)&&(n=c>d)后, m,n 的值是 A 。 A. 0,0 B. 0,1 C. 1,0 D. 1,1

(完整版)C语言选择题(附答案)

第一单元C语言概述 一、选择题 1、C语言中主函数的个数为(A)个。 A)1 B)2 C)无穷个D)任意个 2、以下关于C语言描述错误的是(D)。 A)一个C程序总是从main函数开始执行T B)每个语句和数据声明的最后必须有一个分号T C)C语言的注释符是以“/*”开始并以“*/”结束的T D)一个C程序可以包含多个main函数F 3、C 语言源程序文件后缀为(C )。 A).EXE B).OBJ C).C D).ASM 4、C语言是由(C )组成的。 A)子程序B)主程序与子程序C)函数D)过程 5、C语言属于(B )语言 A)机器语言B)汇编语言C)高级语言D)面向对象语言 第二单元C语言基础 一、选择题 1、C语言中普通整型变量int在内存中占(B )字节。 A)1 B)2 C)3 D)4 2、下列不是C语言基本数据类型的是(A )。 A)字符型B) 整型 C) 浮点型D) 结构体 3、有关自增、自减运算,以下只有(D )是正确的。 A) ---f B) ++78 C) a—b++ D) d++ 4、已知A=7.5,B=2,C=3.6,表达式(A>B && C>A) || (AB)的值是(A )。 A)0 B)10 C)1 D)5

5、若有x=1,y=2,z=3,则表达式(x=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 7、判断整型变量digit是否为数字的正确表达式是(C )。 A) ‘0’<=ch<=‘9’B) (ch>=‘0’)&(ch<=‘9’) C) (ch>=‘0’)&&(ch<=‘9’) D) (‘0’<= ch)AND(‘9’>= ch) 8、一个C程序的执行是从(A )。 A)本程序的main函数开始,到main函数结柬 B)本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C)本程序的main函数开始,到本程序文件的最后一个函数结束 D)本程序文件的第一个函数开始,到本程序main函数结束 9、在以下标识符中,合法的是(C ) A)if B)0xy C)_xy D)case 10、C语言中各种类型的数据其实决定了占用内存的字节数。float占(C )。 A)一字节B)二字节C)四字节D)八字节 11、下列各选项中,(A )是有效的标识符。 A)ab B)3day C)day-3 D)#abc 12、以下叙述正确的是(C ) A) 在C程序中,每行只能写一条语句 B) 若a是实型变量,C程序中不允许a=10这种赋值。 C) 在C程序中,%是只能用于整数运算的运算符 D) 在C程序中,无论是整数还是实数,没有什么区别 13、有输入语句:scanf(“a=%d,b=%d,c=%d”,&a,&b,&c);为使变量a的值为1,b的值为3,c的值为2,则正确的数据输入方式是( B )。 A)132↙B)1,3,2↙ C)a=1 b=3 c=2↙D)a=1,b=3,c=2↙ 14、设整型变量a为5,使b不为2的表达式是( C )。 A)b = a/2 B)b = 6-(--a) C)b=a%2 D)b=a>3?2:1