当前位置:文档之家› c语言选择题解题思路

c语言选择题解题思路

c语言选择题解题思路
c语言选择题解题思路

语法基础

12.正确的用户标识符是(B)

A.3f 标识符不能以数字开头

B._for

C.struct 不能使用关键字

D._f.5 标识符只能包括字母,数字和下划线,不能包括.

14.正确的常量(D)

A.E-5 指数记数法e前必须有数字

B.1E5.1 指数记数法e后的数字必须是整数

C.?a12?字符常量是单引号括起来的单个字符

D.32766L

15.正确的变量名(D)

A.a.bee 标识符只能包括字母,数字和下划线,不能包括.

B.-p11 标识符只能包括字母,数字和下划线,不能包括-

C.int 不能使用关键字

D.p_11

16.正确的字符常量(C)

A.“c”字符常量应由单引号括起来

B.?\\??非法字符常量

C.?W?

D.“\32a?”字符常量应由单引号括起来

17.不正确的字符串常量(A)

A.?abc?字符串常量应由双引号括起来

B.“12?12”

C.“0”

D.“”

19.正确的浮点数(B)

A.e3 指数记数法e前必须有数字

B..62 C语言中,小数点前如果是0可以省略

C.2e4.5 指数记数法e后的数字必须是整数

D.123 是整型,不是浮点数

20.不属于C语言关键字的是(B)

A.continue 结束本次循环

B.integer

C.static 静态变量声明,内部函数声明

D.signed 有符号

23.正确的赋值表达式是(A)

A.a-=(a*3)

B.double(-a) 强制类型转换时,类型名应加括号,(double)(-a)为正确表达式

C.a*3 该表达式正确,但是是算术表达式,不是赋值表达式

D.a*4=3 赋值号左边只能是变量,不能是表达式

24.x=(a=3,b=++a)运行后,x,a,b的值依次为(C)

A.3,3,4

B.4,4,3

C.4,4,4

D.3,4,3

x=(a=3,b=++a(执行后a=4,b=4)) = 4

25.a=(3/4)+3%2运行后a的值为(B)

A.0

B.1

C.2

D.3

(3/4)+3%2 = 0+1 =1

26.符合C语言语法的语句是(C)

A.int a+b=c; 赋值号左边只能是变量,不能是表达式

B.int a=12:b=12:c=12; 同类型变量应使用逗号隔开

C.int a=12,b=12,c=12;

D.int a,b=12,float c=21; 不同类型变量的定义必须分为两条语句,用分号隔开

27.若有定义:int x,a;则语句x=(a=3,a+1)运行后,x,a的值依次为(C)

A.3,3

B.4,4

C.4,3

D.3,4

x=(a=3,a+1(执行后a=3))=4

28.符合C语言语法的表达式是()

A.a=8+b+c,a++

B.a=a^3

C.int(12.3%4) 强制类型转换时,类型名应加括号,(int) (12%4)为正确表达式

D.a=a+1=c+b 赋值号左边只能是变量,不能是表达式

29.若为定义:int a,b;double x;则不符合C语言语法的表达式是(A)

A.x%(-3) %运算符两个运算对象必须是整型,x为double型不符合语法规则

B.a+=-2

C.a=b=2

D.x=a+b

30.若有定义:int x=2,y=3;float I;符合C语言语法的表达式是(B

A.x=x*3=2 赋值号左边只能是变量,不能是表达式

B.x=(y==1)

C.i=float(x) 强制类型转换时,类型名应加括号,(float) (x)为正确表达式

D.i%(-3) %运算符两个运算对象必须是整型,i为float型不符合语法规则

31.若有定义:int x;则语句x=(2*3)+6%5;运行后,x的值是(B)

A.8

B.7

C.6

D.6.5

(2*3)+6%5 = 6+1 = 7

32.错误的是(A)

A.可以用const关键字定义变量const用于定义常量

B.在C程序中,SUM和sum是不同的变量

C.变量名必须由字母或下划线开头

D.变量的类型确定了变量的取值范围

33.若有定义:int x=5,y=6;则表达式x=(y==6)的值为(B)

A.5

B.1

C.6

D.0

x=(y==6) = x=(6==6) = x=1 = 1

34.下面叙述正确的是(B)

A.2/3与2.0/3.0等价2/3是整数除,值为0,2.0/3.0是实数除,值为0.666…

B.(int)2.0/3与2/3等价

C.++5与6等价++5是错误的C表达式

D.?A?与“A”等价…A?是字符常量,“A”是字符串,不等价

36.叙述正确的是(A)

A.强制类型转换运算的优先级高于算术

B.若a和b是整型变量,(a+b)++是合法的(a+b)++是错误的C表达式

C.…A?*‘B’是不合法的合法,等价于65*66

D.“A”+“B”是合法的不合法,字符串表示地址,地址不能进行+运算

37.若有定义:int i=1,j=5;则表达式(++j)*(i--)的值为(C)

A.1

B.0

C.6

D.7

(++j)*(i--) = 6*1 = 6

38.设整型变量a为5,使b不为2的表达式是(C)

A.b=(++a)/3 (++a)的值为6,(++a)/3的值2

B.b=6-(--a) (--a)的值为4,6-(--a)的值为2

C.b=a%2 a%2的值为1

D.b=a/2 a/2的值为2

39.若有定义:int a=1,b=2,c=3;则语句++a||++b&&++c;运行后b的值为(C)

A.1

B.0

C.2

D.3

++a||++b&&++c = 2||++b&&++c = 1,因此b,c不变

40.若有定义:int i,j;则表达式(i=2,j=5,i++,i+j++)的值是(B)

A.7

B.8

C.9

D.10

(i=2,j=5,i++(执行后i=3),i+j++) = 8

41.若有定义:int a,b;则表达式(a=2,b=5,a*2,b++,a+b)的值是(B)

A.7

B.8

C.9

D.10

(a=2,b=5,a*2(执行后a=2),b++(执行后b=6),a+b)=8

42.若有定义:int i=2,j=5;则表达式(i+1,j+1,(++i)+(j--))的值为(A)

A.8

B.6

C.7

D.5

(i+1(执行后i=2),j+1(执行后j=5),(++i)+(j--)) = 8

43.若有定义:int i=3,k;则语句k=(i--)+(i--);运行后k的值为(C)

A.4

B.5

C.6

D.7

先使用再-,因此k=(i--)+(i--)=3+3=6

45.若己定义:float m;拟从键盘输入135.78这一数据变量给变量m,则应选用的语句是(D)

A.scanf(“%5.2f”,&m); scanf中不能使用精度

B.scanf(“%3.2f”,&m);

C.scanf(“%6.2f”,&m);

D.scanf(“%6f”,&m);

46.己知double a;使用scanf函数输入一个数值给变量a,正确的函数调用是(D)

A.scanf(“%ld”,&a); %ld,应输入long int型

B.scanf(“%d”,&a); %d,应输入int型

C.scanf(“%7.2f”,&a); %f,应输入float型,该选项中.2错误,不能使用精度

D.scanf(“%lf”,&a);

47.己知char a;使用scanf()函数输入一个字符给变量a,不正确的函数调用是(B)

A.scanf(“%d”,&a);

B.scanf(“%lf”,&a);

C.scanf(“%c”,&a);

D.scanf(“%u”,&a);

字符变量以ASCII码存储于内存,ASCII码为数值,可使用整型输入,因此%d,%u也适用于字符型变量

49.以下程序段运行后的输出结果是(D)

int k=11;

printf(“k=%d,k=%o,k=%x\n”,k,k,k);

A.k=11,k=13,k=c

B.k=11,k=12,k=13

C.k=11,k=11,k=b

D.k=11,k=13,k=b

%d为十进制,因此输出10,%o为八进制,因此输出13,%x为十六进制,因此输出b 50.若有定义:int x=1234,y=123,z=12;则主事句printf(“%4d+%3d+%2d”,x,y,z);运行后的输出结果为(D)

A.123412312

B.12341234123412341231231231212

C.1234+1234+1234

D.1234+123+12

%4d,以4的宽度输出x,即输出1234,+号原样输出,%3d,以3的宽度输出y,即输出123,+号原样输出,%2d以2的宽度输出z,即输出12。因此输出结果为1234+123+12 51.int a;char c1,c2;

scanf(“%d%c%c”,&a,&c1,&c2);

若要求a,c1,c2的值分别为10,A,B,正确的数据输入是(A)。

A.10AB

B.10 A B

C.10A B

D.10 AB

%c会接收空白字符(如空格,TAB和回车),因此输入10后应输入AB,不需要加任何空格

52.int a=0,b=0,c=0;

if(a&&++b) c++;

printf(“%d,%d\n”,b,c);

以上程序运行结果是(A)

A.0,0

B.1,2

C.2,2

D.1,2

逻辑表达式a&&++b中,先执行a为0即为假,由于不完全计算,&&左边为假即得整个表达式为假,因此++b没有执行。if的表达式为假,因此c++不执行。b,c无变化,运行结果为0,0

53.以下程序的运行结果是(D)

int a=65;

char c=?A?;

printf(“%x,%d”,a,c);

A.65,a

B.41,a

C.65,65

D.41,65

%x以十六进制输出变量a中的值,即十进制65转为十六进制41后输出

%d以十进制输出变量c中的值,即‘A’转为十进制65(65即‘A’的ASCII码值)后输出。

54.若己定义:int a=5;float b=63.72;以下语句中能输出正确值的是(B)

A.printf(“%d %d”,a,b);

B.printf(“%d %.2f”,a,b);

C.printf(“%.2f %.2f”,a,b);

D.printf(“%.2f %d”,a,b);

a为整型,应使用格式说明符%d,b为float型,应使用格式说明符%.2f

55.运行以下程序段时编译出错,其原因是(B)

char c1=‘8’,c2=‘2008’;

printf(“%c,%d\n”,c1,c2);

A.c2是字符变量,只能赋以字符常量,不能赋以字符串常量(‘2008’不是字符串常量)

B.字符串要用“2008”表示,而‘2008’不是字符串表示

C.‘2008’只能赋值给字符数组(‘2008’是错误表达式)

D.字符变量不能用%d格式输出(可以使用%d输出)

56.若己定义:int a=3,b=15,c;则语句c=a>b;运行后c的值为(B)

A.1

B.0

C..t.

D..f.

a>b(3>15)的值为假,假即为0,因此c=a>b,c=0

58.若己定义:int a=-36,b=-30,c;则语句c=a

A.1

B.t.

C.0

D.f.

a

59.能正确表示数学关系式800>=y>=500的C语言表达式是(A)

A.(y<=800)&&(y>=500)

B.(y<=800)AND(y>=500) 没有AND这个关键字

C.800>=y>=500 此表达式等价于(800>=y)>=500

D.(y<=800)&(y>=500) &为按位与,应为逻辑与&&

60.若有定义:int x=3,y=4;则表达式!x||y的值为(A)

A.1

B.0

C.3

D.4

!x||y = !3||4 = 0||1 =1

61.若有定义:int i=7.j=8;则表达式i>=j||i

A.1

B.变量i的值

C.0

D.变量j的值

i>=j||i=8||7<8 = 0||1 = 1

62.若希望当a的值为奇数时,表达式的值为真,a的值为偶数时,表达式的值为假。则不能满足要求的表达式是(C)

A.a%2==1

B.!(a%2==0)

C.!(a%2)

D.a%2

可对每个表达式代入某个特定的数进行验证,假若代入奇数3

A中3%2==1为真,符合题目要求

B中!(3%2==0)为真,符合题目要求

C中!(3%2)为假,不符合题目要求

D中3%2为真,符合题目要求

63.若有定义:int x=3,y=4,z=5;则值为0的表达式是(D)

A.‘x’&&‘y’120&&121 = 1

B.x<=y 3<=4 = 1

C.x||y+z&&y-z 3||y+z&&y-z = 1

D.!((x

64.若有定义:int a=5,b=2,c=1;则表达式a-b

A.0

B.1

C.2

D.-1

5-2<1||2==1 = 0||0 =0

65.C语言中,能正确表示条件10

A.10

B.x>10||x<20

C.x>10&&<20

D.(x>10)&&(x<20)

66.以下运算符优先级最低的是(D)P408

A.<<

B.&

C.>>

D.|

67.己知double a=5.2;则正确的赋值表达式是(A)

A.a+=a-=(a=4)*(a=3)

B.a=a*3=2 赋值号左边只能是变量,不能是表达式

C.a%3 %运算符两个运算对象必须是整型,a为double型不符合语法规则

D.a=double(-3) 强制类型转换时,类型名应加括号,(double) (-3)为正确表达式

68.己知char a=‘R’;则正确的赋值表达式是(A)

A.a=(a++)%4

B.a+2=3 赋值号左边只能是变量,不能是表达式

C.a+=256—256—为错误的C表达式

D.a=‘\078’错误C字符常量

69.己知int a=‘R’;则正确的表达式是(A)

A.a%10

B.a=int(3e2) 强制类型转换时,类型名应加括号,(double) (-3)为正确表达式

C.2*a=a++ 赋值号左边只能是变量,不能是表达式

D.a=a+a=a+3 赋值号左边只能是变量,不能是表达式

70.设有语句float x=3.0,y=3.0;使x值为6.0的表达式是(D)

A.x*=y-4 x=x*(y-4)=3*(-1)=-3

B.x*=y x=x*y=9

C.x-=y+4 x=x-(y+4)=3-7=-4

D.x+=y x=x+y=6

71.若有定义:float x=3.5;int z=8;则表达式x+z%3/4的值为(B)

A.3.75

B.3.5

C.3

D.4

x+z%3/4 = 3.5+8%3/4 =3.5+2/4 = 3.5+0=3.5

72.设有语句int x=3,y=3,a=1,b=2;表达式(x=a>b)&&(y=b>a)的值是(D)

A.8

B.1

C.5

D.0

(x=a>b)&&(y=b>a) = (x=1>2)&&(y=2>1) = (x=0)&&(y=1) = 0&&1 =0

73.若有定义:int a=2,b=3;float x=3.5,y=2.5;则表达式(float)(a+b)/2+(int)x%(int)y的值是(A)。

A.3.5

B.3.0

C.2.5

D.2.0

(float)(a+b)/2 = (float)5/2 = 5.0/2 = 2.5

(int)x%(int)y = (int)3.5%(int)2.5 = 3%2 = 1

74.若有定义:int b=7;float a=2.5,c=4.7;表达式a+(b/2*(int)(a+c)/2)%4的值是(C)

A.2.5

B.3.5

C.4.5 D5.5

a+(b/2*(int)(a+c)/2)%4 = a+(7/2*(int)(a+c)/2)%4 = a+(3*(int)(a+c)/2)%4 =

a+(3*7/2)%4 = a+(21/2)%4 = a+(10)%4 = 2.5+2 =4.5

75.若有定义:int a=6,b=2;char c1=‘a’,c2=‘b’;则表达式a+b%5+c2-c1的值是(C)

A.7

B.8

C.9

D.表达式错误

a+b%5+c2-c1 = a+2%5+c2-c1 = 6+2+98-97 = 9

控制结构

78.输入10,输出结果是(D)

int a;

scanf(“%d”,&a); //输入后a的值为10

if(a++>10) //比较10>10为假,比较完后执行a++,执行后a的值为11

printf(“%d\n”,a);

else

printf(“%d\n”,++a); //先执行++a,得出a的值为12后输出

A.2

B.11

C.3

D.12

79.以下程序的运行结果是(B)

int x,y=1,z;

z=-1;

if(z==0) //z==0值为假

z=-z;

else

x=y>0?3:5; // y>0?3:5,y>0值为真,取3

printf(“%d\n”,x);

A.-1

B.3

C.1

D.5

80.对于整型变量x,下述if语句与赋值语句:x=x%2==0?1:0;不等价(B)

A.if(x%2!=0) x=0;else x=1;//代入奇数3,x取0,等价

B.if(x%2) x=1;else x=0;//代入奇数3,x取1,不等价

C.if(x%2==0) x=1;else x=0;

D.if(x%2==1) x=0;else x=1;

x=x%2==0?1:0 x是偶数时取1,x是奇数时取0

81.以下程序段运行的结果是(C)

int a,b,c,x;

a=b=c=0;x=15;

if(!a) x--; //!a = !0 =1为真,执行x--,执行后x=14

else if(b);

if(c) x=3; //c值为0 即为假

else

x+=4; //执行后x=18

printf(“%d\n”,x);

A.15 B,17 C.18 D.19

82.若有定义:int a=1,b=2,c=3;则执行以下程序段后a,b,c的值分别为(D)

if(a

{c=a; //执行后c的值为1

a=b; //执行后a的值为2

b=c;} //执行后b的值为1

A.a=1,b=2,c=3;

B.a=2,b=3,c=1

C.a=2,b=3,c=3

D.a=2,b=1,c=1

83.以下程序段运行后变量a的值为(D)

int x=6,y=5;

int a;

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

A.0

B.1

C.6

D.5

(--x==y++)?x:y+1 = (5==5++)?x:y+1 = 1?5:y+1 = 5

84.以下程序的运行结果是(C)

int n=‘e’;

switch(n--) //使用再-,根据‘e’寻找入口为default

{

default:printf(“error”); //输出error

case …a?:

case …b?:printf(“good”);break; //输出good后执行break,跳出switch case …c?:printf(“pass”);

case …d?:printf(“warn”);

}

A.error

B.good

C.error good

D.warn

85.以下程序的运行结果是(C)

int n=‘c’;

switch(n++) //

{

default:printf(“error”);

case …a?:

case …b?:printf(“good”);break;

case …c?:printf(“pass”); //输出pass

case …d?:printf(“warn”); //输出warn

}

A.pass

B.warn

C.pass warn

D.error

86.以下程序的运行结果是(D)

int n=5;

if(n++>=6) //先使用再加,5>=6为假,接着执行n++,执行完n的值为6 printf(“%d\n”,n);

else

printf(“%d\n”,++n); //执行++n后n的值为7后输出

A.4

B.5

C.6

D.7

88.若有定义:int a=1,b=2,c=3;运行后c的值为(D)

if(a>b) //1>2为假

c=a*b;

else

c=a-b; //c=1-2=-1

A.2

B.0

C.1

D.-1

89.若有定义:int x;以下不会产生死循环的是()死循环:循环条件永远为真

A.for(;(x=getchar())!=?\n?;);

B.while(1) {x++;}

C.for(i=10; ;i++);

D.for(; ;x+=1);

91.count+=2运行次数为(B)

int I,j,count=0;

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

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

{count+=2;printf(“%d”,count);}

A.8

B.10

C.16

D.20

93.循环体运行次数(B)

int i=10,x;

for(;i<10;i++) x=x+i;

A.10

B.0

C.1

D.无限

i<10 = 10<10 循环条件为假,不进入循环体,因此循环体运行次数为0

94.变量n的值(D)

int i=1,n=1;

for(;i<3;i++) {continue;n=n+i;}

continue语句作用为结束本次循环,继续下次循环,n=n+i未执行,n值不变

95.输出结果(A)

int i;

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

switch(i)

{ case 1:printf(“%d”,i);

case 2:printf(“%d”,i);

default: printf(“%d”,i);}

A.011122

B.01222

C.012020

D.120

运行步骤:

i

0 switch(0) 入口为default,执行printf(“%d”,i);即输出0

1 switch(1) 入口为case 1,执行printf(“%d”,i); printf(“%d”,i); printf(“%d”,i);即输出111

2 switch(2) 入口为case 2,执行printf(“%d”,i); printf(“%d”,i);即输出22

96.运行结果(C)

int sum=0,item=0;

while(item<5)

{ item++

sum+=item;

if(sum>=6) break;}

printf(“%d\n”,sum);

A.10

B.15

C.6

D.7

运行步骤:

item

0item<5为真进入循环体,执行item++;

1执行sum+=item; sum=sum+item=0+1=1 if(sum>=6) 1>=6为假

判断循环表达式item<5即1<5为真,继续循环,执行item++

2执行sum+=item; sum=sum+item=1+2=3 if(sum>=6) 3>=6为假

判断循环表达式item<5即2<5为真,继续循环,执行item++

3执行sum+=item; sum=sum+item=3+3=6 if(sum>=6) 6>=6为真,执行break;跳出循环

所以printf(“%d\n”,sum);输出sum的值为6

97.运行结果(B)

int sum=0,item=0;

while(item<5)

{ item++;

if(item==2) continue;

sum+=item;}

printf(“%d\n”,sum);

A.10

B.15

C.6

D.7

运行步骤:

item

0item<5为真进入循环体,执行item++;

1if(item==2) 1==2为假执行sum+=item; sum=sum+item=0+1=1 判断循环表达式item<5即1<5为真,继续循环,执行item++

2if(item==2) 2==2为真执行continue,结束本次循环判断循环表达式item<5即2<5为真,继续循环,执行item++

3if(item==2) 3==2为假执行sum+=item; sum=sum+item=1+3=4 判断循环表达式item<5即1<5为真,继续循环,执行item++

4if(item==2) 4==2为假执行sum+=item; sum=sum+item=4+4=8 判断循环表达式item<5即4<5为真,继续循环,执行item++

5if(item==2) 5==2为假执行sum+=item; sum=sum+item=8+5=13 判断循环表达式item<5即5<5为真,跳出循环,执行printf(“%d\n”,sum);输出sum的值,即为13

98.sum的值(C)

int i,j=1,sum=0;

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

{sum+=j;

j++;}

A.5

B.3

C.6

D.4

运行步骤:

i

1 执行sum=sum+j=0+1=1;执行j++后,j=2

2 执行sum=sum+j=1+3=3;执行j++后j=3

3 执行sum=sum+j=3+3=6;执行j++后j=4

99.运行结果(D)

int y=10;

do

{ y--;}

while(--y); //等价于while(y=y-1)

printf(“%d\n”,y--);

A.1

B.2

C.-1

D.0

当循环条件为假时跳出do..while,即—y为假时跳出循环,--y等价于y=y-1,即为表达式y=y-1为假时跳出循环,即y为假时跳出循环,y为假即y=0;因此y=0时结束do....while。接着执行printf(“%d\n”,y--);,先输出再减,因此运行结果为0

数组

101.正确的数组定义为(A)

A.int a[10];

B.int n=10,a[n]; //数组定义时数组长度不允许为变量

C.int N=10;int a[N]; //数组定义时数组长度不允许为变量

D.int n;scanf(“%d”,&n);int a[n]; //数组定义时数组长度不允许为变量

102.若己定义:int a[13];则不能正确引用a数组元素的是(C)。

int a[13];表明数组a中有13个元素,因此下标范围从0~12,下选项中下标0~12为正确A.a[0]

B.a[10]

C.a[10+3] //即a[13],下标超出范围,错误

D.a[13-5] //即a[8],正确

103.若有定义:int a[3]={0,1,2};则a[1]的值为(B)

A.0

B.1

C.2

D.3

int a[3]={0,1,2};表明数组a中,a[0]为0,a[1]为1,a[2]为2

104.若有定义:int a[5]={1,2,3,4,5};

则语句a[1]=a[3]+a[2+2]-a[3-1];运行后a[1]的值为(A)

A.6

B.5

C.1

D.2

a[1]=a[3]+a[2+2]-a[3-1]=a[3]+a[4]-a[2]=4+5-3=6

106.(D)

char s[10];

s=“abcd”; //数组名为地址常量,不能被改变

printf(“%s\n”,s);

A.执行时输出:abcd

B.执行时输出:a

C.执行时输出:ab

D.编译不通过

107.运行结果(C)

int i=0,a[]={7,5,7,3,8,3};

do

{ a[i]+=2; }

while(a[++i]>5)

for(i=0;i<6;i++) printf(“%d”,a[i]);

A.9 7 9 5 10 5

B.9 5 9 3 10 3

C.9 5 7 3 8 3

D.7 5 7 3 8 3

运行步骤:

执行a[i]+=2;即a[0]+=2;执行后a[0]为9,判断a[++i]>5,a[1]>5为假,因此结束循环。for(i=0;i<6;i++) printf(“%d”,a[i]);为输出数组a,因此输出9 5 7 3 8 3

108.运行结果()

int i=0,a[]={1,2,3,4,5};

do

{ a[i]+=10;}

while(a[++i]>2);

for(i=0;i<5;i++) printf(“%d”,a[i]);

A.11 2 3 4 5

B.1 2 3 4 5

C.11 12 13 14 15

D.11 12 3 4 5

运行步骤:

执行a[i]+=10;即a[0]+=10;执行后a[0]为11,判断a[++i]>2,a[1]>2为假,因此结束循环。for(i=0;i<5;i++) printf(“%d”,a[i]);为输出数组a,因此输出11 2 3 4 5

110.运行结果(C)

int i=0,a[]={6,5,3,7};

do

{ a[i]++;}

while(a[i]<4);

for(i=0;i<4;i++) printf(“%d”,a[i]);

A.6537

B.7563

C.7537

D.5673

运行步骤:

执行a[i]++;即a[0]++;执行后a[0]为7,判断a[i]<4,a[0]<4为假,因此结束循环。

for(i=0;i<4;i++) printf(“%d”,a[i]);为输出数组a,因此输出7537

111.输出结果(A)

int t[][3]={1,2,3,4,5,6,7,8,9,10,11,12};

printf(“%d\n”,t[2][1]);

A.8

B.7

C.4

D.2

t

1 2 3

4 5 6

7 8 9

10 11 12

112.s的值(B)

int a[3][3]={1,2,3,1,2,3,1,2,3};

int i,j,s=1;

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

for(j=i;j<3;j++) s*=a[i][j];

A.18

B.108

C.2

D.12

运行步骤:

a 1 2 3

1 2 3

1 2 3

i j

0 0 s=s*a[0][0]=1*1=1

1 s=s*a[0][1]=1*2=2

2 s=s*a[0][2]=2*3=6

1 1 s=s*a[1][1]=6*2=12

2 s=s*a[1][2]=12*3=36

2 2 s=s*a[2][2]=36*3=108

113.以下不能对二维数组arr进行正确初始化的语句(C)

A.int arr[2][3]={0};

B.int arr[][3]={1,2,3,4,5};

C.int arr[2][3]={{1,2},{3,4},{5,6}};

//定义时为2行3列,初始化时为3行(一对花括号表示1行)

D.int arr[2][3]={{1},{3,4,5}};

114.若有定义:int a[3][4]={{1,2},{0},{1,2,3}};则a[1][1]的值为(A)

A.0

B.{1,2}

C.1

D.3

a 1 2 0 0

0 0 0 0

1 2 3 0

115.若有定义:int a[3][3];则表达式&a[2][1]-a的值是()。

A.7

B.8

C.6

D.9

a a[0][0],a[0][1],a[0][2]

a[1][0],a[1][1],a[1][2]

a[2][0],a[2][1],a[2][2]

116.若有定义:int i=0,x=0;int a[3][3]={1,2,3,4,5,6,7,8,9};则以下程序段运行后x的值是(C)。for(;i<3;i++) x+=a[i][2-i];

A.0

B.12

C.15

D.18

A 1 2 3

4 5 6

7 8 9

i

0 x=x+a[i][2-i]=0+a[0][2]=0+3=3

1 x=x+a[i][2-i]=3+a[1][1]=3+5=8

2 x=x+a[i][2-i]=8+a[2][0]=8+7=15

117.若有定义:int a[2][3];则对数组元素的非法引用是(D)

A.a[0][1/2] 等价于a[0][0]

B.a[1][1]

C.a[4-4][0] 等价于a[0][0]

D.a[0][3] 列下标的范围为0~2,选项中为3错误

118.数组定义中正确的是(C)

A.int a[2][]={1,2,3,4,5}; //第二维长度不能为空

B.int a[][2]={{0},{}}; //最后一行为空不需要写

C.int a[2][2]={{1,2},{3}};

D.int a[][]={1,2,3,4}; //第二维长度不能为空

119.若有定义int a[][3]={1,2,3,4,5,6,7,8,9};则表达式sizeof(a)/sizeof(a[0])的值是(A)

A.3

B.4

C.5

D.9

sizeof(a):求数组a大小,为9*2=18

sizeof(a[0]):求数组第一行大小,为3*2=6

sizeof(a)/sizeof(a[0])=18/6=3

120.s的值是(A)

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

int I,j,s=1;

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

for(j=i+1;j<3;j++)

s*=a[i][j];

A.6

B.120

C.24

D.480

运行步骤:

a 1 2 3

4 5 1

2 3 4

i j

0 1 s=s*a[i][j]=1*a[0][1]=1*2=2

2 s=s*a[i][j]=2*a[0][2]=2*3=6

1 2 s=s*a[i][j]=6*a[1][2]=6*1=6

2

122.定义:char str1[10],str2[10]=“Fujian”;则能将字符串“Fujian”赋给数组str1的正确语句是(B)

A.str1=“Fujian”; //数组名是地址常量,不能被改变

B.strcpy(str1,str2);

C.strcpy(str2,str1); //将str1复制到str2

D.str1=str2; //数组名是地址常量,不能被改变

123.如有定义:char str[3][2]={…a?, …b?, …c?, …\0?, …e?, …f?};则printf(“%s”,str[0]);的输出结果是(D)A.ab B.adcef C.abc\0 D.abc

%s作用为从输出地址开始输出到\0结束,str[0]指第一行地址,因此输出abc

124.char str[8]={“Fujian”};则分配给数组str的存储空间是(C)个

A.6

B.7

C.8

D.9

存储空间依据数组定义时的数组个数,为8

若问strlen(str)则为6

125.若有定义:char a[]=“abcdef”;char b[]=“xyz”;则以下程序运行后屏幕输出(B)strcpy(a,b);

printf(“%c”,a[2]);

A.c

B.z

C.\0

D.d

a abcdef

b xyz

strcpy(a,b);执行后

a xyz\0ef

b xyz

printf(“%c”,a[2]);输出z

126.运行后输出(C)

char a[]=“abc\0mis”;

printf(“%d”,strlen(a));

A.5

B.8

C.3

D.4

strlen(a)计算a中\0前有多少个元素,

127.若有定义:int a=2;则a=strcmp(“miss”,“miss”);运行后a的值是(B)

A.1

B.0

C.1 D2

strcmp函数,相等返回0,大于返回正数,小于返回负数

例:strcmp(“computer”, “compare”) ; 返回值为…u?-…a?

129.输出为(A)

char str[80];

strcpy(str, “hello”);

printf(“%d”,strlen(str)); //输出str数组\0前有多少个字符

A.5

B.6

C.7

D.80

130.若有定义:char str1[6]=“abcdm”,*ps,*str2=“abcdef”;(B)是正确的

A.strcpy(str1,str2); //str1长度为6,str2长度为7,不能复制

B.表达式strcmp(str1,str2)的值大于0 //比较‘m’与‘e’

C.str1=str2; //数组名不能被赋值

D.表达式strlen(str1)的值为6 //应为5

131.己有定义:char str1[15]={“university”},str2[15];正确的是(D)

A.str2=str1; //数组名是地址常量不能被改变

B.str2=“college”; //数组名是地址常量不能被改变

C.scanf(“%s”,&str2); //str2已经是地址,不需要再加地址运算符&

D.printf(“%s”,str1);

132.定义:char s1[20]=“You are ”,s2[9]=“welcome!”;若有形成字符串“You are welcome!”,正确语句是(A)

A.strcat(s1,s2);

B.strcpy(s1,s2); //复制

C.s1+s2; //非法语句

D.s1&s2; //非法语句

函数

134.运行结果(A)

int fun(int array[4][4])

{ int j;

for(j=0;j<4;j++) printf(“%2d”,array[2][j]);

printf(“\n”);

main()

{

int a[4][4]={0,1,2,0,1,0,0,4,2,0,0,5,0,4,5,0};

fun(a);

}

A.2 0 0 5

B.1 0 0 4

C.0 1 2 0

D.0 4 5 0

运行步骤:

a 0 1 2 0

1 0 0 4

2 0 0 5

0 4 5 0

fun(a);调用fun函数

j

0 输出array[2][j],即array[2][0]=2

1 输出array[2][j],即array[2][1]=0

2 输出array[2][j],即array[2][2]=0

3 输出array[2][j],即array[2][3]=5

136.屏幕输出为(B)

int f(int x,int y) //x=2 y=3

{ return (x+y); } //返回5

main()

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

c=f(a,b); //c=5

printf(“%d+%d=%d\n”,a,b,c);

}

A.0

B.2+3=5

C.2+3=0

D.3+2=5

137.输出为(D)

int a=2,b=3

int max(int a,int b) //a=4 b=3

{ int c;

c=a>b?a:b; //c=4

return (c);

}

main()

{ int a=4;

printf(“%d”,max(a,b)); //输出max函数返回值是4 }

A.2,3

B.2

C.3

D.4

138.运行结果是(B)

fun(int i) //i=3

int a=2;

a=i++; //a=3

printf(“%d”,a); //输出3

}

main()

{

int a=5,c=3;

fun(c);

printf(“%d”,a); //输出5

}

A.4 5

B.3 5

C.4 4

D.3 3

139.若有如下函数定义:(D)

int fun()

{ static int k=0;

return ++k;

}

以下程序段运行后输出为()

int i;

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

printf(“%d”,fun());

A.0

B.1

C.5

D.6

运行步骤:

i

1 调用函数fun,k的值为1

2 调用函数fun,k的值为上次调用后的值加1,为2

3 调用函数fun,k的值为上次调用后的值加1,为3

4 调用函数fun,k的值为上次调用后的值加1,为4

5 调用函数fun,k的值为上次调用后的值加1,为5

执行printf(“%d”,fun());再调用fun,k的值为上次调用后的值加1,为6,因此输出6

140.输出结果(D)

int global=100;

fun()

{

int global=5;

return ++global; //全局与局部同名,局部有效,因此++global的值为6

}

main()

{ printf(“%d\n”,fun()); }

A.100 B,101 C.5 D.6

142.运行结果()

fun(int x,int y) //x=10 y=6

{

int z;

z=(x

}

main()

{ int a=10,b=6;

printf(“%d\n”,fun(a,b)); //输出函数返回值为4

}

A.4 B,16 C.10 D.6

143.运行结果(B)

main()

{

int min(float x,float y);

float a,b;

int c;

a=-6.3;b=-7.9;

c=min(a,b);

printf(“%d\n”,c);

}

int min(float x,float y) //x=-6.3 y=-7.9

{

float z;

if(x>y) z=y; //x>y为真,z=y=-7.9

else z=x;

return z; //返回值为整形,因此需要取整为-7

}

A.-7.9 B,-7 C.-6.3 D.-6

144.运行结果(C)

#define M(a,b) a*b

main()

{

int x=3,y=2,s1,s2;

s1=M(x+y,x-y);

s2=M(x-y,x+y);

printf(“%d,%d\n”,s1,s2);

}

A.-1,7

B.5,5

C.7,-1

D.5,-5

s1=M(x+y,x-y); s1=M(a,b)=a*b=x+y*x-y=3+2*3-2=7 s2=M(x-y,x+y); s2=M(a,b)=a*b=x-y*x+y=3-2*3+2=-1

148.若有定义:#define PI 3,表达式PI*2*2的值为(A)

A.12 B,4 C.3 D.不确定

3*2*2=12

149.屏幕输出为(C)

#define MIN(a,b) ((a)<(b)?(a) : (b))

main()

{

int x=2,y=3,z;

z=2*MIN(x,y);

printf(“%d”,z);

}

A.2

B.3

C.4

D.6

z=2*MIN(x,y)=2*((x)<(y)?(x) : (y))=2*(2<3:2:3)=2*2=4

151.输出结果(C)

#include

#define ONE 1

#define TWO ONE+1

#define THREE TWO+1

main()

{

printf(“%d\n”,THREE-ONE);

}

A.产生错误

B.1

C.2

D.3

THREE-ONE=TWO+1-1=ONE+1+1-1=1+1+1-1=2

153.运行结果(B)

#define ADD(x) x+x

main()

{

int m=1,n=2,k;

k=ADD(m+n)*3; //k=ADD(x)*3=x+x*3=m+n+m+n*3=1+2+1+2*3=10 printf(“%d”,k);

}

A.9

B.10

C.12

D.18

154.运行结果(B)

#define M 10

#define S(x) x*x

#define F(x) (x*x)

main()

{

int n1,n2;

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

相关主题
文本预览
相关文档 最新文档