当前位置:文档之家› (完整版)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 te mp

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 lel0xFFOO 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,因此实型变量中允许存放整型数

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、A

若以下变量均是整型,且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

若有定义: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,456 0xf"a"

*39、D

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

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

*40、B

设变量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

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

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)不定

下面程序的功能是计算:至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}#&

& &

& &

*

历年二级C语言笔试真题及答案

1 2009年9月全国计算机等级考试二级笔试 试卷 1)下列数据结构中,属于非线性结构的是 A )循环队列 B) 带链队列 C) 二叉树 D )带链栈 2)下列数据结果中,能够按照“先进后出”原则存取数据的是 A) 循环队列 B) 栈 C)队列 D)二叉树 3)对于循环队列,下列叙述中正确的是 A )队头指针是固定不变的 B )队头指针一定大于队尾指针 C )队头指针一定小于队尾指针 D )队头指针可以大于队尾指针,也可以小于队尾指针 4)算法的空间复杂度是指 A )算法在执行过程中所需要的计算机存储空间 B )算法所处理的数据量 C )算法程序中的语句或指令条数 D )算法在执行过程中所需要的临时工作单元数 5)软件设计中划分模块的一个准则是 A) 低内聚低耦合 B) 高内聚低耦合 C) 低内聚高耦合 D) 高内聚高耦合 6)下列选项中不属于结构化程序设计原则的是 A) 可封装 B) 自顶向下 C) 模块化 D) 逐步求精 7)软件详细设计产生的图如下: 该图是 A) N-S 图 B) PAD 图 C) 程序流程图 D) E-R 图 8)数据库管理系统是 A )操作系统的一部分B) 在操作系统支持下的系统软件C) 一种编译系统 D) 一种操作系统 9)在E-R 图中,用来表示实体联系的图形是 A) 椭圆图B) 矩形C) 菱形D) 三角形 10)有三个关系R ,S 和T 如下: 其中关系T 由关系R 和S 通过某种操作得到,该操作为 A) 选择 B) 投影 C) 交 D) 并 11)以下叙述中正确的是 A )程序设计的任务就是编写程序代码并上机 B )程序设计的任务就是确定所用数据结 构 C )程序设计的任务就是确定所用算法 D )以上三种说法都不完整 12)以下选项中,能用作用户标识符的是 A )void B )8_8 C )_0_ D )unsigned 13)阅读以下程序 #include main() { int case; float printF; printf(“请输入2个数:”); scanf(“%d %f”,&case,&pjrintF); printf(“%d %f \n”,case,printF); } 该程序编译时产生错误,其出错原因是 A )定义语句出错,case 是关键字,不能 用作用户自定义标识符B )定义语句出错,printF 不能用作用户自定义标识符 C )定义语句无错,scanf 不能作为输入函 数使用 D )定义语句无错,printf 不能输出case 的值 14)表达式:(int)((double)9/2)-(9)%2的值是 A )0 B )3 C )4 D )5 15)若有定义语句:int x=10;,则表达式 x-=x+x 的值为 A )-20 B )-10 C )0 D )10 16)有以下程序 #include main() { int a=1,b=0; printf(“%d,”,b=a+b); printf(“%d \n”,a=2*b); } 程序运行后的输出结果是 A )0,0 B )1,0 C )3,2 D )1,2 17)设有定义:int a=1,b=2,c=3;,以下语 句中执行效果与其它三个不同的是 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;} 18)有以下程序 #include main() { int c=0,k; for (k=1;k<3;k++) switch (k) {default: c+=k case 2: c++;break; case 4: c+=2;break; } printf(“%d \n”,c); } 程序运行后的输出结果是 A )3 B )5 C )7 D )9 19)以下程序段中,与语句:k=a>b?(b>c?1:0):0;功能相同的是 A )if((a>b)&&(b>c)) k=1;else k=0; B )if((a>b)||(b>c) k=1;else k=0; C )if(a<=b) k=0;else if(b<=c) k=1; D )if(a>b) k=1;else if(b>c) k=1; else k=0; 20)有以下程序 #include main() { char s[]={“012xy”};int i,n=0; for(i=0;s[i]!=0;i++) if(s[i]>=?a?&&s[i]<=?z?) n++; printf(“%d \n”,n); } 程序运行后的输出结果是 A )0 B )2 C )3 D )5 21)有以下程序 #include main() { int n=2,k=0; while(k++&&n++>2); printf(“%d %d \n”,k,n); } 程序运行后的输出结果是 A )0 2 B )1 3 C )5 7 D )1 2 22)有以下定义语句,编译时会出现编译错误的是 A )char a=?a? B )char a=?\n?; C )char a=?aa?; D )char a=?\x2d?; 23)有以下程序 #include main() { char c1,c2; c1=?A?+?8?-…4?; c2=?A?+?8?-…5?; printf(“%c,%d \n”,c1,c2); } 已知字母A 的ASCII 码为65,程序运行后的输出结果是

C语言练习试题和答案

单项选择题: 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)。 [i] 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# 语言中的简单数据类型包括(D)。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是C。 A) B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

全国计算机等级考试二级C语言真题

2009年3月二级C语言笔试真题((1)—(10)每小题2分,(11)—(50)每题1分,共60分) 下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确选项涂写在答题卡相应位置上,答在试卷上不得分。 (1)下列叙述中正确的是 A)栈是“先进先出”的线性表 B)队列是“先进先出”的线性表 C)循环队列是非线性结构 D)有序性表既可以采用顺序存储结构,也可以采用链式存储结构 (2)支持子程序调用的数据结构是 A)栈B)树C)队列D)二叉树 (3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10B)8C)6D)4 (4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序 D)堆排序 (5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是 A)编译软件 B)操作系统 C)教务管理系统 D)汇编程序 (6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试的程序进行“错误定位”是程序调试的必要步骤 C)程序调试通常也称为Debug D)软件测试应严格执行测试计划,排除测试的随意性 (7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性

C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度D)内聚性是指模块间互相连接的紧密程度 (8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训 (9)有两个关系R,S如下: 由关系R通过运算得到关系S,则所使用的运算为 A)选择B)投影C)插入D)连接 (10)将E-R图转换为关系模式时,实体和联系都可以表示为A)属性B)键C)关系D)域 (11)以下选项中合法的标识符是 A)1-1B)1—1C)-11D)1-- (12)若函数中有定义语句:intk;,则 A)系统将自动给k赋初值0 B)这时k中值无定义 C)系统将自动给k赋初值-1 D)这时k中无任何值 (13)以下选项中,能用作数据常量的是 A)o115B)0118C))115L (14)设有定义:intx=2;,以下表达式中,值不为6的是A)x*=x+1 B)x++,2*x C)x*=(1+x)

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语言历年真题及答案【篇一:国家计算机二级c语言历年真题及答案】 class=txt>c语言程序设计 (考试时间90分钟,满分100分) 一、选择题((1)—(10)、(21)—(40)每题2分,(11)—(20)每题1分,共70分) (1)下列数据结构中,属于非线性结构的是 a)循环队列 b) 带链队列 c) 二叉树 d)带链栈 (2)下列数据结果中,能够按照“先进后出”原则存取数据的是 a) 循环队列 b) 栈 c)队列 d)二叉树 (3)对于循环队列,下列叙述中正确的是 a)队头指针是固定不变的 b)队头指针一定大于队尾指针 c)队头指针一定小于队尾指针 d)队头指针可以大于队尾指针,也可以小于队尾指针 (4)算法的空间复杂度是指 a)算法在执行过程中所需要的计算机存储空间 b)算法所处理的数据量 c)算法程序中的语句或指令条数 d)算法在执行过程中所需要的临时工作单元数 (5)软件设计中划分模块的一个准则是 a) 低内聚低耦合 b) 高内聚低耦合 c) 低内聚高耦合 d) 高内聚高耦合 (6)下列选项中不属于结构化程序设计原则的是 a) 可封装 d) 自顶向下

c) 模块化 d) 逐步求精 (7)软件详细设计产生的图如下: 该图是 a) n-s图 b) pad图 c) 程序流程图 d) e-r图 (8)数据库管理系统是 a)操作系统的一部分 b) 在操作系统支持下的系统软件 c) 一种编译系统 d) 一种操作系统 (9)在e-r图中,用来表示实体联系的图形是 a) 椭圆图 b) 矩形 c) 菱形 d) 三角形 (10)有三个关系r,s和t如下: 其中关系t由关系r和s通过某种操作得到,该操作为 a) 选择 b) 投影 c) 交 d) 并 (11)以下叙述中正确的是 a)程序设计的任务就是编写程序代码并上机调试 b)程序设计的任务就是确定所用数据结构 c)程序设计的任务就是确定所用算法 d)以上三种说法都不完整 (12)以下选项中,能用作用户标识符的是 a)void b)8_8 c)_0_ d)unsigned (13)阅读以下程序

c语言试题及答案

1、以下正确的说法是( B ) (A) 用户若需要调用标准库函数,调用前必须重新定义 (B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 (C) 系统根本不允许用户重新定义标准库函数 (D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调 2、以下正确的函数声明形式是( A ) (A) double fun(int x, int y) (B) double fun(int x; int y) (C) double fun(int x, int y); (D) double fun(int x,y); 3、以下正确的函数形式是( D ) (A) double fun(int x, int y) { 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、以下正确的说法是( A ) 在C语言中 (A) 实参和与其对应的形参各占用独立的存储单元 (B) 实参和与其对应的形参共占用一个存储单元 (C) 只有当实参和与其对应的形参同名时才共占用存储单元 (D) 形参是虚拟的,不占用存储单元 5、若调用一个函数,且此函数中没有return语句,则正确的说法是( A ) 该函数 (A) 没有返回值 (B) 返回若干个系统默认值 (C) 能返回一个用户所希望的函数值 (D) 返回一个不确定的值 6、以下不正确的说法是( B ) C语言规定 (A) 实参可以是常量、变量和表达式 (B) 形参可以是常量、变量和表达式 (C) 实参可以为任意类型 (D) 形参应与其对应的实参类型一致 7、以下正确的说法是( C ) (A) 定义函数时,形参的类型说明可以放在函数体内 (B) return后边的值不能为表达式 (C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 (D) 如果形参与实参的类型不一致,以实参类型为准 8、C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是( B ) (A) 地址传递 (B) 单向值传递 (C) 由实参传给形参,再由形参传回给实参 (D) 由用户指定传递方式

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语言试题(含答案)

二级C语言试题 一、判断题(2×8=16分) 1、printf()函数总是从新行的起始位置开始打印。( F ) 2、所有的变量在使用前都必须予以申明。(F) 3、在申明变量时必须给出变量的类型。(T) 4、C语言认为变量number和NuMbEr是相同的。( F) 5、打印三行输出的C语言程序必须用三条printf语句。(F) 6、求余运算符%只能用于两个整数操作数。(T) 7、switch选择结构中必须有default子句。(F) 8、如果x>y或ay&&a

C语言试卷及答案

一、选择题(每题 1 分,共 20 分) 1. C 语言程序的三种基本结构是顺序结构、选择结构和结构。 A、循环 B、递归 C、转移 D、嵌套 2. 下列标识符中,合法的是_______ 。 A) unsigned B) 5ab C) INT# D)_num2 3. 若float x ;x = 10/4 ;x的值是。 A、2.5 B、2.0 C、3 D、 2 4. 表达式!x 等价于。 A、x==0 B、x==1 C、x != 0 D、x != 1 5. 算术运算符、赋值运算符和关系运算符的运算优先级按从高到低的顺序依次为。 A、算术运算、赋值运算、关系运算 B、关系运算、赋值运算、算术运算 C、算术运算、关系运算、赋值运算 D、关系运算、算术运算、赋值运算 6. 能将高级语言编写的源程序转换为目标程序的是。 A、链接程序 B、解释程序 C、编译程序 D、编辑程序 7. 下列语句定义pf为指向float类型变量f的指针,是正确的。 A、float f, *pf = f; B、float f, *pf = &f; C、float *pf = &f, f; D、float f, pf = f; 8. 一个C程序的执行是从。 A、本程序的main函数开始,到main函数结束 B、本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C、本程序的main函数开始,到本程序文件的最后一个函数结束 D、本程序文件的第一个函数开始,到本程序main函数结束 9. 能正确表示“当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) 10. 对两个数组a和b进行如下初始化 char a[]=“ABCDEF”;char b[]={ …A?,?B?,?C?,?D?,?E?,?F?}; 则以下叙述正确的是。 A、a和b数组完全相同 B、a和b长度相同 C、a和b中都存放字符串 D、a数组比b数组长度长 11. 是不正确的字符常量。 A、'\n' B、'1' C、"a" D、'\101' 12. 若变量已正确定义,语句“if(a>b) k=0; else k=1;”和等价。 A、k=(a>b)?1:0; B、k=a>b; C、k=a<=b; D、a<=b ? 0 : 1; 13. 设变量定义为“int x, *p=&x;”,则&*p相当于。 A、p B、*p C、x D、*&x 14. 有两个字符数组a、b,则以下正确的输入语句是。 A)gets(a,b); B) scanf(“%s%s”,a,b); C) scanf(“%s%s”,&a,&b); D) gets(“a”),gets(“b”); 15. C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是。 A、地址传递 B、单向值传递

全国计算机二级C语言操作题题库

1.程序Cmody021.c输出如下所示图形: * *** ***** ******* ********* #include void main() { int i,j;for(i=1;i<=5;i++) { for(j=1;j<=5-i;j++)printf(" "); for(j=1;j<=2*i-1;j++) printf("*"); printf("\n"); } } 2.程序Cmody032.c的功能是:输出201-300之间的所有素数,统计总个数。#include #include void main() { int num; printf("\n"); num=fun(); printf("\nThe total of prime is %d",num); getch(); } int fun() { int m,i,k,n=0; for(m=201;m<=300;m++) { k=sqrt(m+1); for(i=2;i<=k;i++) /**/if(m/i==0)/**/ break; /**/if(i==k)/**/ { printf("%-4d",m); n++;

if(n%10==0)printf("\n"); } } return n; } 3. 程序Cmody041.c,其功能是统计输入字符串中小写英文字母的个数。如输入:abcdEFGHIJK123 输出:4 #include #include main() { char str1[128]; /**/int i,len,sum=0;/**/ gets(str1); len=strlen(str1); for(i=0;i='a'&&str1[i]<='z')/**/ sum++; } printf("%d\n",sum); getch(); } 4.程序Cmody051.c,其功能是统计输入字符串中大写英文字母的个数。如输入:abcDEFGH123 输出:5 #include #include main() { /**/char str1[128]/**/ int i,len,sum=0; printf("Please input a string:\n"); scanf("%s",str1); len=strlen(str1); for(i=0;i='A'&&str1[i]<='Z') /**/sum++;/**/

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

全国计算机等级考试 历年真题2009年3月二级C语言笔试真题及答案

全国计算机等级考试历年真题2009年3月二级C语言笔试真题及答案 一、选择题(每题2分,共计70分) 1.(1)下列叙述中正确的是 A)栈是先进先出的线性表 B)队列是"先进后出"的线性表 C)循环队列是非线性结构 D)有序线性表即可以采用顺序存储结构,也可以采用链式存 储结构 A B C D 2.(2)支持子程序调用的数据结构是 A)栈 B)树 C)队列 D)二叉树 A B C D 3.(3)某二叉树有5个度为2的结点,则该二叉树中的叶子结点数是 A)10 B)8 C)6 D)4 A B C D 4.(4)下列排序方法中,最坏情况下比较次数最少的是 A)冒泡排序 B)简单选择排序 C)直接插入排序

D)堆排序 A B C D 5.(5)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下列 属于应用软件的是 A)编译程序 B)操作系统 C)教务管理系统 D)汇编程序 A B C D 6.(6)下面叙述中错误的是 A)软件测试的目的是发现错误并改正错误 B)对被调试程序进行"错误定位"是程序调试的必要步骤 C)程序调试也成为Debug D)软件测试应严格执行测试计划,排除测试的随意性 A B C D 7.(7)耦合性和内聚性是对模块独立性度量的两个标准。下列叙述中正确的是 A)提高耦合性降低内聚性有利于提高模块的独立性 B)降低耦合性提高内聚性有利于提高模块的独立性 C)耦合性是指一个模块内部各个元素间彼此结合的紧密程度 D)内聚性是指模块间互相连接的紧密程度 A B C D 8.(8)数据库应用系统中的核心问题是 A)数据库设计 B)数据库系统设计 C)数据库维护 D)数据库管理员培训

(完整版)C语言试题及答案解析

C语言 一、选择题(第题2分,共20分) 1.一个C程序的执行是从 A 。 A) 本程序的main函数开始,到main函数结束 B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束 D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2.若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 C 。 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 3.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为 C 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647 4.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 D 。 A) float B) char C) int D) double 5. putchar函数可以向终端输出一个 D 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 6. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 7.判断char型变量ch是否为大写字母的正确表达式是 C 。 A) ‘A’<=ch<=‘Z’ B) (ch>=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 8.已知int x=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 9.以下程序段______C__. x=-1; do{ x=x*x; } while(!x); A)是死循环 B)循环执行二次 C)循环执行一次 D)有语法错误 10.以下正确的描述是___B____. A)continue语句的作用是结束整个循环的执行

计算机二级C语言测试题及答案解析(一)

2016年计算机二级C语言测试题及答案解析(一)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 )。

B、a[i] C、a2_i D、int t 5~8题为相同类型题 考点:标识符的命名规则 只能由字母、数字、下划线构成 数字不能作为标识符的开头 关键字不能作为标识符 选项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

选项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 %为求余运算符,该运算符只能对整型数据进行运算。且符号与被模数相同。5%2=1;5%

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语言题库及答案

2016年计算机二级c语言题库及答案 一、选择题(每小题1分,共40小题,共40分) 1.设循环队列的存储空间为Q(1:35),初始状态为front=rear=35。现经过一系列入队与退队运算后,front=15,rear=15,则循环队列中的元素个数为( )。 或35 2.下列关于栈的叙述中,正确的是( )。 A.栈底元素一定是最后入栈的元素 B.栈操作遵循先进后出的原则 C.栈顶元素一定是最先入栈的元素 D.以上三种说法都不对 3.下列链表中,其逻辑结构属于非线性结构的是( )0、 A.双向链表 B.带链的栈 C.二叉链表 D.循环链表 4.在关系数据库中,用来表示实体间联系的是( )。 A.网状结构 B.树状结构 C.属性 D.二维表 5.公司中有多个部门和多名职员,每个职员只能属于一个部门,一个部门可以有多名职员。则实体部门和职员间的联系是( )。 :m联系 :n联系 :1联系 :l联系

6.右两个关系R和S如下: 则由关系R得到关系S的操作是( )。 A.自然连接 B.并 C.选择 D.投影 7.数据字典(DD)所定义的对象都包含于( )。 A.软件结构图 B.方框图 C.数据流图(DFD图) D.程序流程图 8.软件需求规格说明书的作用不包括( )。 A.软件设计的依据 B.软件可行性研究的依据 C.软件验收的依据 D.用户与开发人员对软件要做什么的共同理解 9.下面属于黑盒测试方法的是( )。 A.边界值分析 B.路径覆盖 C.语句覆盖 D.逻辑覆盖 10.下面不属于软件设计阶段任务的是( )。 A.制订软件确认测试计划 B.数据库设计 C.软件总体设计 D.算法设计 11.以下叙述中正确的是( )。 A.在C语言程序中,main函数必须放在其他函数的最前面 B.每个后缀为C的C语言源程序都可以单独进行编译 C.在C语言程序中,只有main函数才可单独进行编译

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语言试题及答案

《C语言》课程综合复习资料 一、单选题 1. 在C语言中,字符型数据在存中的存储形式是 A)原码 B)补码 C)反码 D)ASCII码 2. 在C语言中,十进制数47可等价地表示为 A) 2f B) 02f C) 57 D) 057 3. 设有定义:int x=12,n=5; 则表达式 x%=(n%2) 的值为 A) 0 B) 1 C) 2 D) 3 4. 设有定义语句:char str[][20]={,"Beijing","中国石油大学"},*p=str; 则printf("%d\n",strlen(p+20)); 输出结果是 A)10 B) 6 C) 0 D) 20 5. 已定义以下函数: fun(int *p) { return *p; } 该函数的返回值是 A)不确定的值 B)形参p所指存储单元中的值 C)形参p中存放的值 D)形参p的地址值 6. C语言中,函数返回值的类型是由 A)return语句中的表达式类型决定 B)调用函数的主调函数类型决定 C)调用函数时的临时类型决定 D)定义函数时所指定的函数类型决定 7. 有以下函数定义: void fun( int n , double x ) { …… } 若以下选项中的变量都已正确定义并赋值,则对函数fun的正确调用语句是 A) fun( int y , double m ); B) k=fun( 10 , 12.5 ); C) fun( 10 , 12.5 ); D) void fun( 10 , 12.5 ); 8. 以下选项中不能正确赋值的是 A) char b[]={′H′,′e′,′l′,′l′,′o′,′!′}; B) char b[10];b="Hello!";

相关主题
文本预览