当前位置:文档之家› 福建省C语言选择题汇编(不下后悔)

福建省C语言选择题汇编(不下后悔)

福建省C语言选择题汇编(不下后悔)
福建省C语言选择题汇编(不下后悔)

0在C语言中,合法的字符常量是(D)。

A. '字'

B. "A"

C."ABC"

D.'\x41'

1下面叙述正确的是(B)。

A.程序中必须包含有输入语句

B.变量按所定义的类型存放数据

C.main函数必须位于文件的开头

D.每行只能写一条语句

2错误的叙述是(D)。

A.一个C语言源程序可由一个或多个函数组成

B.若一条语句较长,也可分写在下一行上

C.C程序必须包含一个main()函数

D.构成C语言源程序的基本单元是算术表达式

3(C)是关于C语言数据类型的正确叙述。

A.变量必须先定义后使用

B.不允许使用空类型

C.枚举类型不是基本类型

D.数组并不是构造类型

4 main( )函数的位置(B)。

A.必须在自定义函数前面

B.可以在自定义函数后面

C.必须位于程序的最前面

D.必须在自定义函数后面

5 C语言函数体由(C)括起来。

A. < >

B. ( )

C.{ }

D.[ ]

6(A)是不正确的叙述。

A.注释说明只能位于一条语句的后面

B. C源程序的基本组成单元是函数

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

D.每条语句最后必须有一个分号

7一个C语言源程序是由(B)。

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

B.函数组成

C.若干过程组成

D.若干子程序组成

8结构化程序设计的三种基本结构是(C)。

A.函数结构、判断结构、选择结构

B.平行结构、嵌套结构、函数结构

C.顺序结构、选择结构、循环结构

D.判断结构、嵌套结构、循环结构

9C源程序的调试是指对源程序进行(C)。

A.录入与编辑

B.查错与编译

C.查错与排错

D.连接与运行

10C语言中,可将一系列语句置于(C)从而构成复合语句。

A.一对尖括号"< >"之间

B.一对圆括号"( )"之间

C.一对花括号"{}"之间

D.一对方框号"[ ]"之间

11构成C源程序的基本单位是(D)。

A.语句

B.变量

C.运算符

D.函数

12以下叙述中正确的是(A)。

A.C源程序中注释部分可以出现在程序中任意合适的地方

B.一对花括号"{}"只能作为函数体的定界符

C.C源程序编译时注释部分的错误将被发现

D.构成C源程序的基本单位是函数,所

有函数名都可以由用户命名

13下面叙述正确的是(D)。

A.每行最多只能写两条语句

B.程序中必需含有自定义函数

C.main()函数必须位于源程序文件的开头

D.所有语句都必须以分号";"结束

14下面叙述错误的是(B)。

A.若一条语句较长,可分写在下一行或多行上

B.构成C语言源程序的基本单位是语句

C.C源程序中大、小写字母是有区别的

D.一个C源程序可由一个或多个函数组成

15(A)是关于C语言数据类型的正确叙述。

A.枚举类型不是基本类型

B.数组不是构造类型

C.变量使用前应定义相应的数据类型

D.不允许使用空类型

16 C源程序中main()函数的位置(C)。

A.必须位于程序的最前面

B.必须在系统库函数后面

C.可以在自定义函数后面

D.必须在自定义函数前面

18下面叙述错误的是(D)。

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

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

C.一个C源程序的执行是从main()函数开始,直到main()函数结束

D.注释说明部分只能位于C源程序的最前面

20C语言的下列运算符中,优先级最高的运算符是(A)。

A. ++

B. +=

C.||

D.!=

21(D)为正确的用户标识符。

A. struct

B. 5f

C._f 0.6

D._for

22C语言基本数据类型包括(B)。

A.整型、实型、逻辑型

B.整型、实型、字符型

C.整型、字符型、逻辑型

D.整型、实型、字符串型

23(A)为合法的常量。

A. 52686L

B. E-7

C.1.2E-2.1

D.'E12'

24(C)为正确的变量名。

A. -k15

B. int

C.k_5

D.k.jeep

25(D)为正确的字符常量。

A. ''\\''

B. "\24m"

C."c"

D.'M'

26(C)为非法的字符串常量。

A. " "

B. "s"

C.'efg'

D."26'62"

27 C语言整型数据在内存中的代码是用(C)表示的。

A.原码

B.反码

C.补码

D.BCD码

28以下选项中,合法的实型常数是(B )。

A. E-3

B. .2E1

C.1E.5

D.1.5E

29下列C语言合法的数据类型关键字是(B)。

A. Double

B. unsigned

C.integer

D.Char

30 Turbo C中,int型数据占用的字节数(B)。

A.由用户自己定义

B.为2个字节

C.是任意的

D.等于所用计算机的字长

31 Turbo C中,基本数据类型存储空间长度的排列顺序是(A)。

A. char

B. char=int

C.char

D.char=int=long int

32以下叙述中正确的是(A)。

A.字符常量用一对单撇号' '作为单个字符的定界符

B.字符常量和字符串常量一样,都是用双引号括起来

C.字符常量存储时,自动在字符后加一个字符结束符号'\0'

D.字符常量和字符串常量所分配的内存空间大小是一样的

33(B)为正确的用户标识符。

A. 3_row

B. max_at

C.union

D.min-5

34C语言的基本数据类型包括(A)。

A.整型、实型、字符型

B.整型、实型、空类型

C.整型、字符型、指针型

D.整型、实型、逻辑型

35(D)为合法的常量。

A. 5,326

B. 3.21E-6.5

C.'b_k'

D.1.23E+8

36(D)为正确的变量名。

A. 5_pro

B. case

C.else

D.pro_5

37(C)为正确的字符常量。

A. 'bcd'

B. '\084'

C.'@'

D.'165'

38(A)为非法的字符串常量。

A. '123'

B. "case"

C."056"

D." "

40已知'A'的ASCII码的十进制值为65,'0'的ASCII码的十进制值为48,则以下程序运行结果是(A)。

main()

{ char ch1,ch2;

ch1='A'+'5'-'3';

ch2='A'+'6'-'3';

printf("%d,%c\n",ch1,ch2); }

A. 67,D

B. C,D

C.C,68

D.67,68

41若有定义int m=6; 则正确的赋值表达式是(C)。

A. m*7

B. m*5=8

C.m-=m*6

D.double(-m)

42语句k=(m=5,n=++m); 运行之后,变量k、m、n的值依次为(D)。

A. 5,5,6

B. 5,6,5

C.6,6,5

D.6,6,6

43语句x=5%4+(4/5); 运行之后,整型变量x的值为(A)。

A. 1

B. 2

C.3

D.0

44(B )语句符合C语言语法。

A. float z=28,int x,y=18;

B. int x=25,y=25,z=25;

C.int x=25:y=25:z=25;

D.int x+y=z;

45若有定义int a,x; 则语句a=(x=8,x+8); 运行后,变量a、x的值依次为(A)。A. 16, 8 B. 8, 8 C.16, 16 D.8, 16

46若变量m, n, t已定义且赋予初值,则正确的表达式是(B)。

A. m=m+1=t-n

B. m=6+n+t,m++

C.m=m\2

D.m=int(5.6%4)

47若有定义:int a,b; float x,则以下不符合C语言语法的表达式是(A)。

A. x%7

B. x/=a-b

C.a=b=2

D.x=(float)a/b

48若有定义:int m=4,n=5;fl oat k;,则以下符合C语言语法的表达式是(B)。

A. (m+n)*=k

B. m=(n==5)

C.k=float(n)/m

D.n%2.5

49若有定义:int a=6; 则语句a*=a-=a/=3; 运行后,a的值是(B)。

A. 10

B. 0

C.34

D.24

50下面关于C语言变量的叙述中,错误的是(A)。

A.可以用define关键字定义变量

B.变量名用大小写字母是有区别的

C.C语言允许不同基本类型的变量之间进行混合运算

D.C语言中要求对变量作强制定义的主要理由是:便于确定类型和分配空间

51若有定义:int a=5,b=2; 则表达式b= (a!=5)的值为(B)。

A. 5

B. 0

C.3

D.2

52逗号表达式(a=15,a*4),a+15 的值为(B)。

A. 15

B. 30

C.75

D.60

53若有定义:int b=-15; 则(A)为正确的赋值表达式。

A. b+=b*3

B. b=*5

C.*b=6

D.b+10=-5

54若有定义:int x,a,b; 语句x=(a=2,b=3,a+b); 运行后,x、a、b的值依次为(C)。

A. 2 3 5

B. 3 2 5

C.5 2 3

D.5 3 2

55若有定义:int a,b=5; 语句a=(b/2)+b%2; 运行后,a的值为(B )。

A. 0

B. 3

C.4

D.2

56(C )语句符合C语言语法。

A. int a=2,b+=a;

B. int a=b=2,c=5;

C.float x=2.3,b,c;

D.float x=3.2,int i,j=6;

57若有定义:int a=3; 语句a+=a-=a*a; 运行后,a的值为(C )。

A. 0

B. -3

C.-12

D.-6

58若有定义int x=1,y=2,n=3; 则(A )为正确的表达式。

A. x=y*3,y=(x+n)/y

B. x=ny

C.float(y/n)

D.(x+y)(y+n)

60下列语句中,符合C语言语法的赋值语句是(C )。

A. a=7+b+c=a+7;

B. a=7+b++=a+7;

C.a=7+b,b++,a+7;

D.a=7=b,c=a+7;

61(A )是正确的叙述。

A. (int)5.0/6 与5/6 等价

B. 'G' 与"G" 等价

C.5/6 与5.0/6.0 等价

D.++3与4 等价

62下面叙述中,错误的是(D )。

A. C语言中的表达式求值,是按其运算符的优先级先高后低的次序进行

B.自增与自减运算符的结合方向为“自右至左”

C.关系运算符的优先级低于算术运算符

D.C语言算术运算符不包含模运算符“%”

63(C )是正确的叙述。

A.表达式"m"+"M" 是合法的

B.若变量x, y为整型,则(a+b)++是合法的

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

D.表达式'm' * 'n' 是不合法的

64若有定义int i=1,j=9; 则表达式(++j)*(i--) 的值为(B )。

A. 0

B. 10

C.9

D.8

65设整型变量x为7,使整型变量y不为2的表达式是(A )。

A. y=x%3

B. y = x/3

C.y =(++x)/3

D.y=8-(--x)

66若已定义int a=3,b=2,c=1; 则语句++a||++b&&++c; 运行后b的值为(D )。

A. 0

B. 3

C.1

D.2

67若有定义:int i=5,j=4;则语句i/=++j; 运行后i的值为(B )。

A. 10

B. 1

C.1.25

D.0

68若已定义:int a=2,b=2; 则表达式(a+(b++), b) 的值是(A )。

A. 2

B. 3

C.4

D.6

69若有定义:int r,x=245; 则语句r=x/100%9; 运行后r的值为(A )。

A. 2

B. 5

C.0

D.27

70若已定义:int i=6,t; 则语句t=3+(--i); 运行后t的值为(C )。

A. 9

B. 7

C.8

D.5

71C语言的% 运算符按运算对象的个数属(C )。

A.单目运算符

B.四目运算符

C.双目运算符

D.三目运算符

72若已定义:int a=5,b=9,c=6; 则语句b++; ++c; a=b-c; 运行后a的值为(B )。A. 5 B. 3 C.2 D.4

73下面叙述正确的是(B )。

A. 2/3 与2%3 等价

B. 5/(int)4.0 与5/4 等价

C.++2 与3 等价

D.++2与--3 等价

74下面叙述错误的是(A )。

A.算术运算符中只有"*"、"/"优先级高于关系运算符

B.模运算符"%"是C语言基本的算术运算符

C.自加和自减运算符只能用于变量,而不能用于常量或表达式

D.算术运算符中不包含"="运算符

75下面叙述正确的是(A )。

A.C语言中整型与字符型变量的混合运算表达式的结果是整型

B.(3+9)++ 是正确表达式

C.模运算符"%"两边运算数的数据类型是任意的

D."abc"+"xxx"是正确表达式

76若有定义:int i=3,j=6; 则表达式(--i)*(j++)的值为(C )。

A. 18

B. 15

C.12

D.10

77若有定义:int a,b=6; 语句a=--b; 运行后,a、b的值分别是(C )。

A. 5 6

B. 6 5

C.5 5

D.6 6

78若有定义:int x,y,z; 语句x=(y=z=3,++y,z+=y); 运行后,x的值为(C )。

A. 6

B. 8

C.7

D.3

80以下程序运行时,若从键盘输入5,则输出结果是( D )。main() { int a; scanf("%d",&a); if(a++>5) printf("%d\n",a); else printf("%d\n",a--); }

A. 7

B. 4

C.5

D.6

81若已定义float x; 要从键盘输入数据36.582给变量x,则应选用(B )语句。

A. scanf("%2.3f",&x) ;

B. scanf("%6f",&x) ;

C.scanf("%6.3f",&x) ;

D.scanf("%5.3f",&x) ;

82若已定义double y; 拟从键盘输入一个值赋给变量y,则正确的函数调用是(C )。

A. scanf("%d",&y) ;

B. scanf("%7.2f",&y) ;

C.scanf("%lf",&y) ;

D.scanf("%ld",&y) ;

83已有定义char s; 使用scanf( )函数输入一个字符给变量s,不正确的函数调用是(D )。

A. scanf("%c",&s) ;

B. scanf("%d",&s) ;

C.scanf("%u",&s) ;

D.scanf("%lf",&s) ;

84函数putchar( ) 的功能是向终端输出(A )。

A.一个字符

B.多个字符

C.一个关系表达式

D.一个实型变量值

85若已定义int a=11; 执行以下语句后的输出结果是( B )。printf("a=%d,a=%o,a=%x\n",a,a,a) ;

A. a=11, a=11, a=b

B. a=11, a=13, a=b

C.a=11, a=13, a=c

D.a=11, a=12, a=13

86若有定义int m=4321,n=123,k=21; 语句printf("%4d+%3d+%2d",m,n,k); 执行后的输出结果是( C )。

A. 4321432143211231231232121

B. 43211232

C.4321+123+21

D.432+123+02

87已有如下定义和输入语句,char c1,c2;int x; scanf("%c%d%c",&c1,&x,&c2); 若要求x、c1、c2的值分别为9、'K'和'H',正确的数据输入是( A )。

A. K9H

B. K 9 H

C.K9 H

D.9KH

88以下程序段的运行结果是(B )。int a=1; printf("%d, %d, %d\n", a, ++a, a++);

A. 3,3,1

B. 2, 2, 1

C.1, 2, 3

D.3, 2, 1

89以下程序的运行结果是(D )。

void main()

{ int a=65;

char c='A';

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

A. A+A=AA

B. 65+A=65A

C.65+65=130

D.65+A=130

90若已定义:int x=7;float y=7.0; 以下语句中能输出正确值的是(B )。

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

B. printf("%d %.3f",x,y);

C.printf("%.3f %.3f",x,y);

D.printf("%.3f %d",x,y);

91putchar函数可以向终端输出一个(A )。

A.字符或字符型变量值

B.整型变量表达式值

C.实型变量值

D.字符串

92若已定义:int a=6;float b=1.5; 要求输出形式为:6 * 1.50=9.00 ,应选用的正确输出语句是(B )。

A. printf("%d * %f=%f",a,b,a*b);

B. printf("%d * %.2f=%.2f",a,b,a*b);

C.printf("%d * %d=%.2f",a,b,a*b);

D.printf("%.2f * %.2f=%.2f",a,b,a*b);

93若有定义float x; 要从键盘输入数据6.02赋给x,则应选用(D )语句。

A. scanf("%8.2f",&x);

B. scanf("%1.2f",&x);

C.scanf("%4.2f",&x);

D.scanf("%f",&x);

94 只能向终端输出一个字符的是(D )。

A. printf()函数

B. scanf()函数

C.getchar()函数

D.putchar()函数

95 若有语句int a; char c; scanf("%3d%c",&a,&c); 为将整数135赋给a,字符'6'赋给c,正确的数据输入方式是(B )。(说明:代表换行,__代表空格)

A. 135__6

B. 1356

C.1356

D.135__6__

96 getchar()函数的功能是获取终端输入的(B )。

A.多个字符

B.一个字符

C.一个实型变量值

D.一个整型变量表达式

97 若有定义int a=8,b=5; 要实现输出形式为: 8*5=40 ,正确的printf()函数调用语句是(D )。

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

B. printf("a*b=a*b\n");

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

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

98若有定义:char c1='A',c2='B'; 语句printf("%d+%d=%d",c1,c2,c1+c2);运行后的结果为(D )。(说明:'A'的ASCII码的十进制值为65)

A. A+B=131

B. 65+66=AB

C.A+B=AB

D.65+66=131

100有以下程序:

main()

{ int c;

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

{ switch(c-'2')

{ case 0 :

case 1 : putchar(c+4);

case 2 : putchar(c+4); break;

case 3 : putchar(c+3);

default: putchar(c+2); break; } }

printf("\n"); } 当输入:247<回车>,程序的输出结果是(B )。

A. 689

B. 6689

C.66778

D.66887

101若已定义int x=5,y=9,z; 语句z=x>=y; 运行后z的值为(C )。

A. 1

B. .t.

C.0

D..f.

102判定逻辑值为“真”的最准确叙述是(D )。

A. 1

B.大于0的数

C.非0的整数

D.非0的数

103若已定义int x=-16,y=-12,z; 语句z=x<=y; 运行后z的值为(B )。

A. .t.

B. 1

C..f.

D.0

104能正确表示数学关系式100≤s<300的表达式为(C )。

A. (s>=100) & (s<300)

B. 100<= s<300

C.(s>=100) && (s<300)

D.(s>=100) and (s<300)

105若定义int a=2,b=3; 则表达式!a||b 的值为(B )。

A. 0

B. 1

C.2

D.3

106若定义int a=-5,b=-8,c=-12; 则表达式a>=b||b

A.变量i的值

B.变量j的值

C.0

D.1

107下列表达式(C )不能用来判断整型变量x中的值是否为奇数。

A. x%2==1

B. !(x%2==0)

C.!(x%2)

D.x%2

108若有定义:int a=3,b=2,c=3; 则值为0的表达式是(D )。

A. (a-b)==(c/b)

B. a>=c

C.c-b||a+b&&(b*c-a-c)

D.(b*c-a-c)&&(b*c-a-b)

109若已定义:int x=4,y=2,z=0; 则表达式(x-y<=y)|| (y=z)的值是(A )。

A. 1

B. 0

C.2

D.4

110若有定义:int a=3,b=2,c=1,k; 则表达式k=a>b>c的值是(A )。

A. 0

B.

C.2

D.3

111以下运算符中优先级最高的是(D )。

A. <=

B. &&

C.||

D.!

112执行以下语句后,b的值是(A )。

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

(a=c>x) || (b=y>z);

A. 0

B. 1

C.-1

D.6

113 x的值在-20至-5之间为“真”,否则为“假”的正确逻辑表达式为(B )。

A. -20

B. x>-20 && x<-5

C.!(x>-20) && !(x<-5)

D.-5

114若有定义:int a; 则表达式(B )不能用来判断a值为奇数是“真”,偶数是“假”。

A. a%2==1

B. !(a%2)

C.a%2

D.!(a%2==0)

115若有定义:int a=1,b=2,c=3,d=4,t=2,k=2; 语句(t=a

A. 2

B. 1

C.0

D.-

116若有定义:int x=1,y=2,z=3; 则表达式(A )的值为0。

A. !((x

B. x>y || x

C.x<=y

D.x|| (y+z && y-z)

117若有定义: int a=3,b=5,c=8; 则表达式!(a-b) || (c-b) 的值为(A )。

A. 1

B. 0

C.2

D.3

118若有定义: int a; 且表达式!a的值为0,则表达式(A )的值为1。

A. a!=0

B. a==0

C.a=0

D.!(a<0 || a>0)

120以下程序运行后,a的值是(C )。

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

A. 101

B. 100

C.8

D.7

121已定义double k=3.6; 则正确的赋值表达式是(D )。

A. k=double(-3.6)

B. k%3

C.k=k*(-1.0)=-3.6

D.k+=k-=(k=1.2)*(k=3)

122已定义char c = 'A' ; 则正确的赋值表达式是(B )。

A. c=\028

B. c=(c++)%4

C.c+1=66

D.c+=127--

123已定义int m ='A'; 则正确的表达式是(C )。

A. 2*m=m++

B. m=int(-3.2)

C.m%3

D.m=m-m=m-5

124设已定义float a=2.0,b=3.0; 使a值为5.0的表达式是(A )。

A. a+= b

B. a*=b+2.0

C.a/=b+2.0

D.a-=b+2.0

125若已定义int m=7;fl oat k=5.5; 则表达式k+ m%2/4 的值为(D )。

A. 6.375

B. 6.75

C.5.75

D.5.5

126若已定义int a=3,b=3,x=1,y=2; 表达式(a=y>x)&&(x=b>a) 的值是(B )。

A. 6

B. 1

C.9

D.0

127若有定义:int a=2,b=3; float x=5; 则表达式x*b/a的值是(A )。

A. 7.5

B. 7

C.6

D.5

128若有定义:int x=8; float y=130;char z='A'; 则表达式x+z%(int)y的值是(C )。[已知'A'的ASCII码的十进制值为65]

A.运行时产生错误信息

B. 8

C.73

D.8.5

129若已定义:int m=7,n=4; fl oat x=3.0,y=8.0,k; 则执行语句k=m/2+n*x/y;后,变量k 的值是(C )。

A. 3

B. 4

C.4.5

D.5

130若有定义:fl oat x=2,y=4,h=3; 下列表达式中与(x+y)*h/2.0计算结果不相符的是( C )。

A. (x+y)*h/2

B. (x+y)*h*1/2

C.(1/2)*(x+y)*h

D.h/2*(x+y)

131表达式2+sqrt(16.0)/4结果的数据类型是(A )。

A. double

B. int

C.char

D.void

132若有定义:int a=4,b=5,c=6; 则表达式(1.0*a+b)/c的值是(A )。

A. 1.5

B. 1

C.4

D.4.5

133下列运算符中优先级最低的是(A )。

A. =

B. !

C.>

D.*

134若有定义:float x=3.5,y=3.6; 则表达式(A )的值为6。

A. (int)x+(int)y

B. x+y

C.(int)(x+y)

D.int(x+y)

135若有定义:int x; char c='A'; 则正确的赋值表达式是(A )。(说明:'A'的ASCII码的十进制值为65,'a'的ASCII码的十进制值为97)

A. x=c+32

B. x=c+'ABC'

C.x=c+'CBA'

D.x='ABC'

136若有定义:float x=2,y; int a=3; 语句y=1*(x+a)/3; 运行后,y的值为(D )。A. 2.0 B. 0 C.1.0 D.1.666667

137若有定义:float x=3.5,y=5.5; 则表达式(B )的值为2。

A. (x+y)%7

B. (int)(x+y)%7

C.int(x+y)%7

D.(int)x+y%7

138若有定义:int a=6,b=7,k=0,t=1; 语句(k=a

A. 0 0

B. 1

C.0 1

D.1 0

140以下程序段的运行结果是( D )。int x=3; d o{ printf("%3d, ", x-=2 ); }whil e(!(--x));

A. 1

B. 30

C.死循环

D.1, -2

141以下程序运行时,若从键盘输入6,则输出结果是(A )。

void main()

{int x;

scanf("%d",&x);

if (x-->6) printf("%d\n",x);

else printf("%d\n",--x); }

A. 4

B. 5

C.6

D.3

142以下程序的运行结果是(C )。

void main()

{int m,n=1,t=1;

if(t== 0) t=-t;

else m=n>=0?7:3;

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

A. 3

B. -

C.7

D.

143对于整型变量a,赋值语句a=(a%3==0?1:0); 与(D )语句不等价。

A. if (a%3= =0) a=1; else a=0;

B. if (a%3!=0) a=0; else a=1;

C.if (a%3) a=0; else a=1;

D.if (a%3) a=1; else a=0;

144以下程序运行的结果是(B )。

void main()

{int x,y,z,a;

x=y=z=1;a=15;

if(!x) a--;

else if(y) ;

if(z) a=3;

else a+=4;

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

A. 15

B. 3

C.19

D.14

145若已定义int a=1,b=2,t=3; 则执行以下程序段后变量a,b,t的值分别为(A )。if(a

A. a=2,b=1,t=2

B. a=2,b=1,t=

C.a=2,b=1,t=3

D.a=3,b=1,t=2

146以下程序段运行后变量k的值为(C )。

int a=3,b=2;

int k;

k=(--a==b++)?a:b+1;

A. 0

B.1

C.2

D.3

147以下程序的运行结果是(C )。

void main()

{ int n=9;

switch(n--)

{ default: printf("%d ",n++);

case 8:

case 7: printf("%d ",n);

break;

case 6: printf("%d ",n++);

case 5: printf("%d ",n); } }

A. 8

B. 7

C.8 9

D.8 7

148以下程序的运行结果是(C )。

void main()

{ int n=8;

switch(n--)

{ default: printf("%d ",n++);

case 8:

case 6: printf("%d ",n);

break;

case 4: printf("%d ",n++);

case 2: printf("%d ",n); } }

A. 8

B. 8 6

C.7

D.8 7

149以下程序的运行结果是(D )。

void main( )

{ int a;

if(a=6)

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

else if(a>6) printf("%d\n",a+2);

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

A.运行时产生错误信息

B. 9

C.8

D.6

150若有定义:int x=10,y=8,a; 则执行语句a=((--x==y)? x: y);后,变量a的值是(A )。

A. 8

B. 9

C.10

D.0

151若有定义: int a=2,b=3,c=1; 则以下程序段的运行结果是(D )。

if(a>b)

if(a>c) printf("%d ",a);

else printf("%d ",b);

printf("%d ",c);

A. 3 1

B. 2

C.3

D.1

152以下条件语句中(其中s1和s2分别表示C语言的语句),(D)与其他三条语句不等价。

A. if(a) s1; else s2;

B. if(a == 0) s2; else s1;

C.if(a != 0) s1; else s2;

D.if(a == 0) s1; else s2;

153以下程序段运行时,若从键盘输入5,则运行结果是(D )。

int a,y=10;

scanf("%d",&a);

if (a>10) y=a+6;

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

A. 10

B. 1

C.16

D.15

154以下程序的运行结果是(B )。

void main()

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

a=3;

if(a>6) a=a+b;

else if(a==6) b=a+c;

else a=b+c;

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

A. 5

B. 8

C.6

D.9

155若有定义:int x,a; 赋值语句a=(x%3==0)?0:1; 与(B )语句不等价。A. if (x%3!=0) a=1; else a=0; B. if (x%3) a=0; else a=1;

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

D.if (!(x%3==0)) a=1; else a=0;

156以下程序段的运行结果是(C )。

int s=15;

switch(s/4)

{case 1: printf("One ");

case 2: printf("Two ");

case 3: printf("Three ");

default: printf("Over "); }

A. Three

B. Two Over

C.Three Over

D.One Over

157以下程序段的运行结果是(C )。

int s=15;

switch(s/4)

{default: printf("Over ");

case 1: printf("One ");

break;

case 2: printf("Two "); }

A. Two

B. Over Two

C.Over One

D.One

158以下程序段运行后x的值为(D )。int a=3,b=6,x; x=(a==b)?a++:--b;

A. 4

B. 3

C.6

D.5

160下列程序段中,非死循环的是(A )。

A. int i=100; while(1) { i=i%100+1; if(i>=100) break; }

B. int k=0; do{ ++k; }while(k>=0);

C.int s=10; while(++s%2+s%2) s++;

D.for(;;)

161若已定义int a; 不会产生死循环的语句是(C )。

A. for( ; ;a+= 2);

B. for(a=10; ;a--);

C.for( ;(a=getchar())!= '\n'; );

D.while(-1) {a++;}

162在循环语句的循环体中,break语句的作用是(B )。

A.继续执行break语句之后的循环体各语句

B.提前结束循环,接着执行该循环后续的语句

C.结束本次循环

D.暂停程序的运行

163以下程序段运行后,循环体中的n+=3; 语句运行的次数为(A )。

int i,j,n=0;

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

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

{n+=3; printf("%d\n",n); } }

A. 6次

B. 9次

C.12次

D.1次

164 do…whil e循环与while循环的主要区别是(D )。

A. while循环体至少无条件执行一次,而do…while循环体可能都不执行

B. do…while循环体中可使用continue语句,while循环体中不允许出现continue语句

C.do…while循环体中可使用break语句,while循环体中不允许出现break语句

D.do…while循环体至少无条件执行一次,而while循环体可能都不执行

165以下程序段运行后,循环体运行的次数为(A )。

int i=8,a=0;

for ( ;i<8;i++)

a+= i;

A. 0次

B. 1次

C.8次

D.无限

166以下程序段运行后变量a的值为(C )。

int i=1,a=0;

for( ;i<3;i++)

{ continue; a+=i; }

A. 6

B. 3

C.0

D.5

167有以下程序:

void main()

{ int i;

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

switch(i)

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

break;

case 2: printf("%d", i);

default : printf("%d", i); } }

执行后输出结果是(A )。

A. 1223

B. 132

C.111223

D.123

168以下程序的运行结果是(C )。

void main()

{int s = 0, i = 0;

while(i< 8)

{i++;

if(i%2==0)

continue;

s+=i; }

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

A. 36

B. 7

C.16

D.12

169以下程序的运行结果是(B )。

void main()

{int s = 0, i = 0;

while(i< 10)

{i++;

if(i % 2==0)

s += i; }

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

A. 20

B. 30

C.25

D.45

170以下程序的运行结果是(C )。

void main()

{int x = 5;

do

{ printf("%2d", x--); }

while(!x); }

A. 5 4 3 2 1

B. 4 3 2 1 0

C.5

D.4

171以下程序的运行结果是(D )。

void main()

{int i,j, k=0;

for(i= 3;i>=1;i--)

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

k += i * j ; }

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

A. 19

B. 29

C.6

D.25

172以下程序运行时,循环体的执行次数是(C )。

void main()

{int i,j;

for(i=0,j=1;i<=j+1;i=i+2,j--)

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

A. 3

B. 2

C.1

D.0

173若有定义: int i,x; (A )不是死循环。

A. for(x=5;x>0;x--) ;

B. while(x=1) ;

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

D.for( ; ;i+=2) ;

174下面叙述正确的是(D )。

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

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

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

D.for循环的循环体可包含多条语句,但必须用花括号{ }括起来

175以下程序段运行后x的值为(B )。

int i,j,x=0;

for(i=3;i>=1;i--)

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

x=x+2;

A. 14

B. 12

C.8

D.10

176以下程序段运行后x的值为(B )。

int i=0,x=2;

while(i++<=5)

{x+=2; }

A. 10

B. 14

C.12

D.8

177若有定义: int i,x=0; 语句for(i=1;i<=3;i++) x+=2;与下列(B )程序段不等价。A. i=1; for( ;i<=3;i++) x+=2; B. i=1; for( ; ;i++) x+=2;

C.for(i=1;i<=3; ) {x+=2; i++;}

D.i=1; for( ;i<=3; ) {x+=2; i++; }

178以下程序段运行后x的值为(D )。

int i=0,x=0;

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

{x+=3;}

A. 15

B. 6

C.12

D.9

180设已定义char s[ ]="\"Name\\Address\023\n";,则字符串所占的字节数是(B )。

A. 19

B. 16

C.18

D.14

181数组元素下标的数据类型为(A )。

A.整型常量、字符型常量或整型表达式

B.字符串常量

C.实型常量或实型表达式

D.任何类型的表达式

182(B )是正确的数组定义。

A. int n=10,x[n];

B. int x[10];

C.int N=10;int x[N];

D.int n; scanf("%d",&n); int x[n];

183若已定义int arr[10]; 则不能正确引用arr数组元素的是(D )。

A. arr[0]

B. arr[1]

C.arr[10-1]

D.arr[7+3]

184若已定义int x[4]={2,1,3}; 则元素x[1]的值为(C )。

A. 0

B. 2

C.1

D.3

185以下程序段运行后,x[1]的值为(B )。

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

x[1]=x[3]+x[2+2]-x[3-1];

A. 6

B. 0

C.1

D.5

186(A )是合法的数组定义。

A. char str[ ]={48,49,50,51,52,53};

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

C.int a[ ]="string";

D.char str[ ]=‘string’;

187若有以下程序:

void main( )

{char s[10]= "ajskdl",r[10];

r=s;

printf("%s\n",r); } 则(D )。

A.执行时输出:ajskdl

B.执行时输出:a

C.执行时输出:aj

D.编译不通过

188下面程序段的运行结果是(C )。

int m[]={5,8,7,6,9,2},i=1;

do{ m[i]+=2; }

while(m[++i]>5);

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

printf("%d ",m[i]);

A. 7 10 9 8 11 4

B. 7 10 9 8 11 2

C.5 10 9 8 11 2

D.5 10 9 8 11 4

189下面程序段的运行结果是(A )。

int m[]={5,8,7,6,9,2},i=1;

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

{if(i % 2 !=0)

m[i]+=10; }

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

printf("%d ",m[i]);

A. 5 18 7 16 9 12

B. 15 18 17 16 19 12

C.15 8 17 6 19 2

D.5 8 7 6 9 2

190下面关于数组的叙述中,正确的是(A )。

A.定义数组后,数组的大小是固定的,且数组元素的数据类型都相同

B.定义数组时,可不加类型说明符

C.定义数组后,可通过赋值运算符"="对该数组名直接赋值

D.在数据类型中,数组属基本类型

191以下程序段的运行结果是(C )。

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

j=1;

for(i=3;i>=0;i--)

{a[i]=a[i]*j;

j=j*3; }

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

printf("%d ",a[i]);

A. 3 6 9 12

B. 18 12 9 4

C.27 18 9 4

D.54 18 9 4

192下面关于字符数组的叙述中,错误的是(B )。

A.可以通过赋值运算符“=”对字符数组整体赋值

B.不可以用关系运算符对字符数组中的字符串进行比较

C.字符数组中的字符串可以整体输入、输出

D.字符数组可以存放字符串

193若有定义:int a[10],i=2; 能正确引用a数组元素的是(B )。

A. a[9+i]

B. a[10-i]

C.a[10]

D.a(7)

194(A )是正确的数组定义。

A. int arr[10];

B. int n=5; int arr[n];

C.int N=5, arr[N];

D.int n; n=5; int arr[n];

195若有定义:int arr[15],n=5; 无法正确引用arr数组元素的是(C )。

A. arr[0]

B. arr[n]

C.arr[10+n]

D.arr[15-n]

196以下程序段运行后x的值为(B )。

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

for(i=0;i<8;i++,i++)

x=x+a[i];

A. 36

B. 16

C.20

D.18

197以下程序段运行后x的值为(A )。

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

for(i=1;i<8;i++,i++)

x=x+a[i];

A. 20

B. 16

C.18

D.36

198下面叙述错误的是(C )。

A.数组中每一个元素都属于同一个数据类型

B. C语言数组名称是数组在内存中的首地址

C.C语言数组长度在定义数组时可不作确定

D.C语言规定可逐个引用数组元素但不能一次引用整个数组

200以下程序段的运行结果是(D )。

main()

{ int i=4,j;

j=i;

pic(i+2*j-2,'*');

putchar('\n');

for(j-=2;j>=0;j--)

{ pic(3-j, ' ');

pic(i+2*j, '*');

putchar('\n'); } }

pic(int len,char c)

{ int k;

for(k=1;k<=len;k++) putchar(c); }

A. *

B. **********

C.****

D.**********

*** ********* ****** ********

***** ********** ******** ******

******* ********** ********** ****

201以下程序段执行后输出的结果是(D )。

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

printf("%d\n",a[1][2]);

A. 2

B. 3

C.6

D.7

202以下程序段执行后p的值是(A )。

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

int j,k,p=1;

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

for(k=j;k<4;k++) p*=a[j][k];

A. 108

B. 18

C.12

D.2

203不能对二维数组a进行正确初始化的语句是(A )。

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

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

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

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

204若有定义:int s[3][4]={{1,2},{0},{3,4,5}};则s[2][1]的值为(B )。

A. 3

B. 4

C.0

D.

205若有定义:int a[3][4];则表达式&a[2][1]-a的值为(C )。

A. 7

B. 8

C.9

D.10

206以下程序段运行后sum的值为(D )。

int k=0,sum=0;

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

for(;k<3;k++)

sum+=a[k][k+1];

A. 9

B. 18

C.19

D.21

207若有定义int a[2][3];则合法引用数组元素的是(A )。

A. a[0][1/2]

B. a[2][1]

C.a[2][3]

D.a[1][3]

208在以下数组定义中,错误的是(A )。

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

B. int a[][2]={{0},{1}};

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

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

209若定义int a[][4]={1,2,3,4,5,6,7,8};则表达式sizeof(a[0][1])的值为(D )。

A. 1

B. 2

C.3

D.4

210以下程序段运行后s的值是(C )。

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.7

D.240

211设已定义: int a[][4]={0,0,0}; 则下列描述正确的是(C )。

A.数组a包含3个元素

B.数组a的第一维大小为3

C.数组a的行数为1

D.元素a[0][3]的初值不为0

212在C语言中,若定义二维数组a[2][3],设a[0][0]在数组中位置为1,则a[1][1]在数组中位置是(C )。

A. 3

B. 4

C.5

D.6

213以下程序段的运行结果是(A )。

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

printf("%d\n",t[1][1]);

A. 5

B. 3

C.4

D.6

214以下程序段运行后s的值是(B )。

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

int i,j,s=0;

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

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

s+=a[i][j];

A. 13

B. 14

C.15

D.12

215以下(C )对二维数组arr的初始化是错误的。

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

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

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

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

216若有定义:int a[3][4]={{1,2},{3,4},{5,6,7}}; ,则a[1][1]的值为(A )。

A. 4

B. 2

C.1

D.3

217若有定义:int a[3][2]; ,则表达式&a[2][1]-a的值为(A )。

A. 5

B. 4

C.3

D.2

218以下程序段运行后x的值为(C )。

int i=0,x=0;

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

for (;i<3;i++)

x+=a[i][i];

A. 0

B. 12

C.15

D.18

220设有下列语句,则(D )是对a数组元素的不正确引用,其中0≤i<10。

int a[10]={0,1,2,3,4,5,6,7,8,9}, *p=a;

A. a[p-a]

B. *(&a[i])

C.p[i]

D.*(*(a+i))

221设已定义: char s1[8],s2[8]="Science"; 能将字符串"Science"赋给数组s1的语句是( C )。

A. s1=s2;

B. strcpy(s2,s1);

C.strcpy(s1,s2);

D.s1="Science";

222以下程序段的运行结果是(A )。

char str[3][2]={ 'a', 'b', 'c', 'd', 'e', 'f'};

str[2][0]= '\0';

汇编语言试题及参考答案

汇编语言试题及参考答案 一,填空题 1.ZF标志位是标志结果是否为零的,若结果,ZF为( 1 ),否则ZF为( 0 ).当ZF为1时,SF为( 0 ) 2.标号可以有两种类型属性.它们是( )和( ) 3.8位无符号整数的表示范围为0--255,写成16进制形式为( ),8位有符号整数的表示范围为-128--+127,写成16进制形式为( ) 4.伪指令DB,GROUP 和NAME 三个标号名字域必须有名字的是( ),不得有名字的是( ),可有可无名字的是( ). 5.循环程序通常由( )( )( )和循环结果外理四部分构成 6.在数值不达式中,各种运算符可可混合使用,其优先次序规则*,/( )于+,-;XOR,OR( )于AND,LT( )于GT 7. 宏指令定义必须由伪指令( )开始,伪指令( )结束,两者之间的语句称为( ) 8.调用程序与子程序之间的参数传递方法有四种,即堆栈法( )( )( ) 9.分别用一条语句实现下述指明的功能 (1)栈顶内容弹出送字变量AYW( ) (2)双字变量AYD存放的地址指针送ES和SI( ) (3)变量AY2类型属性送AH( ) (4)不允许中断即关中断( ) (5)将字符串'HOW ARE YOU!'存入变量AYB( ) (6)子程序返回调用程序( ) (7)地址表达式AYY[4]的偏移地址送字变量ADDR( ) (8)AX的内容加1,要求不影响CF( ) (9)BX的内容加1,要求影响所有标志位( ) (10)若操作结果为零转向短号GOON( ) 二,单选题 1.IBM PC微机中,有符号数是用( )表示的 1.原码 2.补码 3.反码 4.BCD码 2.把汇编源程序变成代码程序的过程是( ) 1.编译 2.汇编 3.编辑 4.链接

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程序的三种基本结构是顺序、选择、循环

汇编语言程序设计期末考试试卷及参考答案

【汇编语言程序设计】期末考试-试卷及参考答案

执行上述两条指令后,正确的结果是( B )。 A.(AX)=1001H; B.(AX)=0FFFH; C.(AX)=1000H; D.(AX)=0111H。 6.串指令中的目的操作数地址一定是由____A_ _提供。()A.ES:[DI] ; B.SS:[BP]; C.DS:[SI] ; D.CS:[IP]。 7.将DX的内容除以2,正确的指令是( C )。 A.DIV 2 ; B.DIV DX,2 ; C.SAR DX,1; D.SHL DX,1。 8. 用户为了解决自己的问题,用汇编语言所编写的程序,称为( B )。 A.目标程序; B.汇编语言源程序; C.可执行程序; D.汇编程序。 9.用一条指令仅实现将AX←BX+SI的方法是( D )。 A.XCHG AX,[BX][SI] ; B.MOV AX,[BX+SI]; C.LEA AX,BX[SI] ; D.LEA AX,[BX][SI]。 10.设SP初值为2000H,执行指令“PUSH AX”后,SP的值是( C )。 A.1FFFH; B.1998H; C.1FFEH; D.2002H。 2. C 二、指出下列指令的出错原因,并改正。(每小题2分,共12分) 1.MOV BX,DL;操作数类型不匹配,改正为:MOV BL,DL 或MOV BX,DX 2.MOV CS,AX;代码段寄存器CS不能作目的操作数,改正为MOV DS,AX 3.ADD AX,DS;段寄存器DS的内容不能作为加法指令的操作数,改正为 MOV BX,DS ADD AX,BX 4.TEST BX,[CX];不能使用CX实现寄存器间接寻址,改正为 MOV SI,CX TEST BX,[SI] 5.SUB [BX],[BP+SI];两个操作数不能同为存储器操作数,且两个操作数的数据类型不确定,改正为:MOV AX,[BX] SUB AX,[BP+SI] 或:MOV AL,[BX] SUB AL,[BP+SI] 6.SHL DX ;没有给出移位次数,改正为SHL DX,1或 SHL DX,CL 三、程序填空题(注意:每空只能填一条指令,并注释说明所填指令的作用!每空3分,共18分) 1.在表TABLE处存放着N个无符号字节数,求表中前10个字节数的总和并

汇编语言复习题(附答案)

汇编语言复习题 注:蓝色标记的为答案,此答案仅供参考,大家自己做一下或看以一下,认为不对的地方,可以提出来一起讨论一下,另外看一下课后老师布置的相应作业。在此文档最后最后附有课 后四、六章的答案,大家抓紧时间复习哦! 一、选择题 1. 把要执行的程序与库文件连接起来形成可执行文件的系统程序是(B )。 A. 汇编程序 B. 连接程序 C. 机器语言程序 D.源代码程序 2. 在8088/8086的寄存器组中,CPU确定下一条指令的物理地址时需要用到的寄存器对是 (C )。 A..SS 和SP B.DS 和DI C.CS 和IP D.ES 和SI 3. 为了使主机访问外设方便起见,外设中的每个寄存器给予一个(C )。 A.物理地址 B. 逻辑地址 C. 端口地址 D. 段地址 4. MOV AX, 3064H,该指令中源操作数采用的寻址方式是(A )。 A.立即 B. 直接 C. 寄存器相对 D. 寄存器间接 5. 换码指令的助记符是(C )。 A. XCHG B. LEAS C.XLAT D. MOV 6. 如果A> B (A、B有符号数)发生转移,应选择的条件转移指令是(JGE )。 7. 下列符号中,可用作标识符的是(C )。 A.MOV B.AX C.MSG1 D.1ABC 8. X DB 10H DUP (1 , 2)内存变量定义语句拥有了( A )个字节的存储空间。 A.20D B.10D C.20H D.10H 9. 当DF=0时,执行串操作指令MOVSB变址寄存器SI、DI的值将(C )。 A.不变 B. 减1 C. 加1 D. 无法确定 10. 如下指令可将AX寄存器内容改变的是(A )。 A. AND AX , BX B . TEST AX , BX C. CMP AX , BX D . XCHG AX , AX 11.16位CPU支持的I/O 地址范围是(D )。 A. 0~0FFFFFH B. 0~0FFFFH C. 0~0FFFH D. 0~0FFH 12. MUL CL指令实现的功能是(A )。 A.无符号乘法:AX AL X CL B.有符号乘法:AX AL X CL C.无符号乘法:DX AL X CL D .有符号乘法:DX AL X CL 13. DOS系统功能调用(INT 21H )中,显示字符串的功能号是(D )。 A.01H B.02H C.08H D. 09H 14. 在16位CPU读取指令时,需要用到的寄存器对是(C )。 A.SS 和SP B.DS 和DI C.CS 和IP D.ES 和SI 15. 下列指令中,源操作数(既第2操作数)属于基址加变址寻址方式是(B )。 A.MOV AX,23H B. MOV AX,[BX+SI] C.SUB AX,[BX] D. ADD AX,BX 16. 有内存变量定义语句:VAR DW 10 DUP(1 , 2), 1234H, VAR的属性TYPE LENGTH和

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、局部变量能否和全局变量重名? 答:能,局部会屏蔽全局。要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。 2、如何引用一个已经定义过的全局变量? 答:extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。 3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量。 可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错. 4、请写出下列代码的输出内容 #include int main(void) { int a,b,c,d; a=10;

c=++a; d=10*a++; printf("b,c,d:%d,%d,%d",b,c,d); return 0; } 答:10,12,120 5、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别? 答: 1) 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。这两者在存储方式上并无不同。这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。 而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。 2) 从以上分析可以看出, 把局部变量改变为静态变量后是改变了它的存储方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域,限制了它的使用范围。3) static函数与普通函数作用域不同,仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义。对

完整版汇编语言试题及答案..doc

一,单项选择题 (每小题 1 分,共 20 分 1-10CCCCAADACB 11-20.ADBBAADDCC 1.指令 JMP FAR PTR DONE 属于 ( C A.段内转移直接寻址 B.段内转移间接寻址 C.段间转移直接寻址 D.段间转移间接寻址 2.下列叙述正确的是 ( A.对两个无符号数进行比较采用CMP 指令 ,对两个有符号数比较用CMP S 指令 B.对两个无符号数进行比较采用CMPS 指令 ,对两个有符号数比较用CM P 指令 C.对无符号数条件转移采用JAE/JNB 指令 ,对有符号数条件转移用JGE/J NL 指令 D.对无符号数条件转移采用JGE/JNL 指令 ,对有符号数条件转移用JAE/J NB 指令 3.一个有 128 个字的数据区 ,它的起始地址为 12ABH:00ABH, 请给出这个数据区最末一个字单元的物理地址是 ( A.12CSBH B.12B6BH

C.12C59H D.12BFEH 4.在下列指令的表示中 ,不正确的是 ( A.MOV AL,[BX+SI] B.JMP SHORT DONI C.DEC [BX] D.MUL CL 5.在进行二重循环程序设计时,下列描述正确的是 ( A.外循环初值应置外循环之外;内循环初值应置内循环之外,外循环之内 B.外循环初值应置外循环之内;内循环初值应置内循环之内 C.内、外循环初值都应置外循环之外 D.内、外循环初值都应置内循环之外,外循环之内 6.条件转移指令 JNE 的测试条件为 ( A.ZF=0 B.CF=0 C.ZF=1 D.CF=1 7.8086CPU在基址加变址的寻址方式中,变址寄存器可以为 ( A.BX 或 CX

汇编语言程序的设计试卷与答案

汇编语言程序设计试卷 一、单项选择题(在每小题的四个备选答案中,选出一个正确的答案,并将其号码填在题干后的括号内,每小题1分,共20分) 1.十六进制数88H,可表示成下面几种形式,请找出错误的表示()。 ① 无符号十进制数136 ② 带符号十进制数-120 ③ 压缩型BCD码十进制数88 ④ 8位二进制数-8的补码表示 2.指令指针寄存器是()。 ① IP ② SP ③ BP ④ PSW 3.当执行指令ADD AX,BX后,若AX的内容为2BA0H, 设置的奇偶标志位PF=1,下面的叙述正确的是()。 ① 表示结果中含1的个数为偶数 ② 表示结果中含1的个数为奇数 ③ 表示该数为偶数 ④ 表示结果中低八位含1的个数为偶数 4.完成将累加器AL清零,并使进位标志CF清零, 下面错误的指令是()。 ① MOV AL,00H ② AND AL,00H

③ XOR AL,AL ④ SUB AL,AL 5.下列指令执行后总是使CF=0,OF=0的是()。 ① AND ② NEG ③ NOT ④ INC 6.完成同指令XCHG AX,BX相同功能的指令或指令序列是()。 ① MOV AX,BX ② MOV BX,AX ③ PUSH AX POP BX ④ MOV CX,AX MOV AX,BX MOV BX,CX 7.设AH=0,AL=06H,BL=09H,执行指令 ADD AL,BL AAA 之后,其结果应是()。 ① AH=01,AL=05 ② AH=1 AL=15 ③ AH=0 AL=0FH ④ AH=0 AL=05 8.设AL=0B4H,BL=11H,指令“MUL BL”和指令“IMUL BL”分别执行后OF,CF的值为

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.static有什么用途?(请至少说明两种) 1)限制变量的作用域 2)设置变量的存储域(堆,主动分配内存也是堆) 1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。 3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用。 4.全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据库,局部变量在栈 6.堆栈溢出一般是由什么原因导致的? 堆栈溢出一般是循环的递归调用导致的,如果使用的大数据结构的局部变量,也可能导致堆栈溢出。没有回收垃圾资源导致的是内存泄露最后内存耗尽。 20.不能做switch()的参数类型是: switch的参数不能为实型。(只能是int char) 9.写出float x 与“零值”比较的if语句。 if(x<0.000001&&x>-0.000001)

3.在c语言库函数中将一个字符转换成整型的函数是atol()吗,这个函数的原型是什么? 函数名: atol 功能: 把字符串转换成长整型数 函数的原型: long atol(const char *nptr); 程序例: #include #include int main(void) { long l; char *str = "98765432"; l = atol(lstr); printf("string = %s integer = %ld\n", str, l); return(0); } 1.对于一个频繁使用的短小函数,在C语言中应用什么实现,在C++中应用什么实现? c用宏定义,c++用inline

汇编语言试题及答案.

一,单项选择题(每小题1分,共20分 1-10CCCCAADACB 11-20.ADBBAADDCC 1.指令JMP FAR PTR DONE属于( C A.段内转移直接寻址 B.段内转移间接寻址 C.段间转移直接寻址 D.段间转移间接寻址 2.下列叙述正确的是( A.对两个无符号数进行比较采用CMP指令,对两个有符号数比较用CMP S指令 B.对两个无符号数进行比较采用CMPS指令,对两个有符号数比较用CM P指令 C.对无符号数条件转移采用JAE/JNB指令,对有符号数条件转移用JGE/J NL指令 D.对无符号数条件转移采用JGE/JNL指令,对有符号数条件转移用JAE/J NB指令 3.一个有128个字的数据区,它的起始地址为12ABH:00ABH,请给出这个数据区最末一个字单元的物理地址是( A.12CSBH B.12B6BH

C.12C59H D.12BFEH 4.在下列指令的表示中,不正确的是( A.MOV AL,[BX+SI] B.JMP SHORT DONI C.DEC [BX] D.MUL CL 5.在进行二重循环程序设计时,下列描述正确的是( A.外循环初值应置外循环之外;内循环初值应置内循环之外,外循环之内 B.外循环初值应置外循环之内;内循环初值应置内循环之内 C.内、外循环初值都应置外循环之外 D.内、外循环初值都应置内循环之外,外循环之内 6.条件转移指令JNE的测试条件为( A.ZF=0 B.CF=0 C.ZF=1 D.CF=1 7.8086CPU在基址加变址的寻址方式中,变址寄存器可以为( A.BX或CX

B.CX或SI C.DX或SI D.SI或DI 8.已知BX=2000H,SI=1234H,则指令MOV AX,[BX+SI+2]的源操作在(中。 A.数据段中偏移量为3236H的字节 B.附加段中偏移量为3234H的字节 C.数据段中偏移量为3234H的字节 D.附加段中偏移量为3236H的字节 9.执行如下程序:( MOV AX,0 MOV AX,0 MOV BX,1 MOV CX,100 A:ADD AX,BX INC BX LOOP A HLT 执行后(BX=( A.99

【汇编语言程序设计】试题及答案合集

《汇编语言程序设计试题及答案》合集 汇编语言程序设计试题及答案 1.对于有符号的数来说,下列哪个值最大(D) A:0F8H B:11010011B C:82 D:123Q 2.下列有关汇编语言中标号的命名规则中,错误的是(D) A:通常由字母打头的字符、数字串组成 B:标号长度不能超过31个字符 C:?和$不能单独作为标号 D:.号不可位于标号首 3.8088/8086存储器分段,每个段不超过(D ) A.64K个字 B.32K个字节 C.1兆个字节 D.64K个字节 4.寻址指令MOV CX, [BX + DI + 20]使用的是哪一种寻址方式(B)A:寄存器寻址B:相对基址变址寻址 C:变址寻址D:基址变址寻址 5.若AX= - 15要得到AX=15应执行的指令是(A ) A.NEG AX B.NOT AX C.INC AX D.DEC AX 6.8086/8088系统执行传送指令MOV时( A) A.不影响标志位 B.影响DF方向标志 C.影响SF符号标志 D.影响CF进位标志 7.若要求一个操作数中的若干位维持不变,若干位置?1?,可以使用(B)A:NOT B:OR C:AND D:XOR 8.下列指令中段默认为堆栈段的是( C) A.MOV AX,[BX+SI+10] B.ADD AX,ES:[SI] C.SUB [BX],[BP][DI] D. MOV DX,[1000H] 9.关于8086/8088微机系列,下列说法哪个是正确的(D) A:一个存储单元由16个二进制位组成,简称字。

B:当存储一个字数据时,低字节放高地址位,高字节放低地址位。 C:在内存空间中,可以无限分配段,且段的大小不受限制。 D:段与段之间可以邻接,也可以重叠。 10.下列关于堆栈的说法,错误的是(D) A:以?先入后出?为原则。 B:栈区最高地址单元的前一个单元为栈底。 C:运行中SP寄存器动态跟踪栈顶位置。 D:压栈和弹出都是以字节为单位。 11.表示过程定义结束的伪指令是( A) A.ENDP B.ENDS C.END D.ENDM 12.BUF1 DB 3 DUP(0,2 DUP (1,2),3) COUNT EQU $-BUF1 符号COUNT等价的值是( B) A.6 B.18 C.16 D.9 13.下列标志位中,可以用来判断计算结果正负的是(B) A:PF B:SF C:DF D:OF 14.下列指令正确的是( CD) A. MOV [100H], [BX] B.MOV DS, ES C. ADD V[BX], CX D.MOV AX, 34H 15.下列哪个寄存器是属于指针寄存器(C) A:SI B:DX C:SP D:ES 二、填空题 (每小题4 分,共 20 分) 1.下列程序段求数组FLD的平均值,结果在AL中。请将程序填写完整(不考虑溢出) FLD DW 10, -20, 30, -60, -71, 80, 79, 56 _LEA SI,FLD______ MOV CX, 8 XOR AX, AX

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语言经典面试题目集锦

1.前言 2.声明和初始化 2.1我如何决定使用那种整数类型? 2.264位机上的64位类型是什么样的? 2.3怎样定义和声明全局变量和函数最好? 2.4extern在函数声明中是什么意思? 2.5关键字auto到底有什么用途? 2.6我似乎不能成功定义一个链表。我试过typedef struct{char*item;NODEPTR next;}*NODEPTR;但是编译器报了错误信息。难道在C语言中一个结构不能包含指向自己的指针吗? 2.7怎样建立和理解非常复杂的声明?例如定义一个包含N个指向返回指向字符的指针的函数的指针的数组? 2.8函数只定义了一次,调用了一次,但编译器提示非法重定义了。 2.9main()的正确定义是什么?void main()正确吗? 2.10对于没有初始化的变量的初始值可以作怎样的假定?如果一个全局变量初始值为``零",它可否作为空指针或浮点零? 2.11代码int f(){char a[]="Hello,world!";}不能编译。 2.12这样的初始化有什么问题?char*p=malloc(10);编译器提示``非法初始式"云云。 2.13以下的初始化有什么区别?char a[]="string literal";char*p="string literal";当我向p[i]赋值的时候,我的程序崩溃了。 2.14我总算弄清除函数指针的声明方法了,但怎样才能初始化呢? 3.结构、联合和枚举 3.1声明struct x1{...};和typedef struct{...}x2;有什么不同? 3.2为什么struct x{...};x thestruct;不对? 3.3一个结构可以包含指向自己的指针吗? 3.4在C语言中实现抽象数据类型什么方法最好? 3.5在C中是否有模拟继承等面向对象程序设计特性的好方法? 3.6我遇到这样声明结构的代码:struct name{int namelen;char namestr[1];};然后又使用一些内存分配技巧使namestr数组用起来好像有多个元素。这样合法和可移植吗? 3.7是否有自动比较结构的方法? 3.8如何向接受结构参数的函数传入常数值? 3.9怎样从/向数据文件读/写结构? 3.10我的编译器在结构中留下了空洞,这导致空间浪费而且无法与外部数据文件进行"二进制"读写。能否关掉填充,或者控制结构域的对齐方式? 3.11为什么sizeof返回的值大于结构的期望值,是不是尾部有填充? 3.12如何确定域在结构中的字节偏移? 3.13怎样在运行时用名字访问结构中的域? 3.14程序运行正确,但退出时却``core dump''了,怎么回事? 3.15可以初始化一个联合吗?

汇编语言试题及答案

一,单项选择题(每小题1分,共20分) 1.指令JMP FAR PTR DONE属于() A.段内转移直接寻址 B.段内转移间接寻址 C.段间转移直接寻址 D.段间转移间接寻址 2.下列叙述正确的是() A.对两个无符号数进行比较采用CMP指令,对两个有符号数比较用CMPS 指令 B.对两个无符号数进行比较采用CMPS指令,对两个有符号数比较用CMP 指令 C.对无符号数条件转移采用JAE/JNB指令,对有符号数条件转移用JGE/JN L指令 D.对无符号数条件转移采用JGE/JNL指令,对有符号数条件转移用JAE/JN B指令 3.一个有128个字的数据区,它的起始地址为12ABH:00ABH,请给出这个数据区最末一个字单元的物理地址是() A.12C5BH B.12B6BH C.12C5AH D.12BFEH 4.在下列指令的表示中,不正确的是() A.MOV AL,[BX+SI] B.JMP SHORT DONI C.DEC [BX] D.MUL CL 5.在进行二重循环程序设计时,下列描述正确的是() A.外循环初值应置外循环之外;内循环初值应置内循环之外,外循环之内B.外循环初值应置外循环之内;内循环初值应置内循环之内 C.内、外循环初值都应置外循环之外 D.内、外循环初值都应置内循环之外,外循环之内 6.条件转移指令JNE的测试条件为() A.ZF=0 B.CF=0 C.ZF=1 D.CF=1 7.8086CPU在基址加变址的寻址方式中,变址寄存器可以为()A.BX或CX B.CX或SI C.DX或SI D.SI或DI 8.已知BX=2000H,SI=1234H,则指令MOV AX,[BX+SI+2]的源操作在()中。 A.数据段中偏移量为3236H的字节 B.附加段中偏移量为3234H的字节 C.数据段中偏移量为3234H的字节 D.附加段中偏移量为3236H的字节 9.执行如下程序:()

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语言面试题大汇总,个人觉得还是比较全

4. static有什么用途?(请至少说明两种) 1.限制变量的作用域 2.设置变量的存储域 7. 引用与指针有什么区别? 1) 引用必须被初始化,指针不必。 2) 引用初始化以后不能被改变,指针可以改变所指的对象。 2) 不存在指向空值的引用,但是存在指向空值的指针。 8. 描述实时系统的基本特性 在特定时间内完成特定的任务,实时性与可靠性 9. 全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据库,局部变量在堆栈 10. 什么是平衡二叉树? 左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于1 11. 堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源 12. 什么函数不能声明为虚函数? constructor 13. 冒泡排序算法的时间复杂度是什么? O(n^2) 14. 写出float x 与“零值”比较的if语句。 if(x>0.000001&&x<-0.000001) 16. Internet采用哪种网络协议?该协议的主要层次结构? tcp/ip 应用层/传输层/网络层/数据链路层/物理层 17. Internet物理地址和IP地址转换采用什么协议? ARP (Address Resolution Protocol)(地址解析協議) 18.IP地址的编码分为哪俩部分? IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。 2.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出 C程序。 循环链表,用取余操作做 3.不能做switch()的参数类型是: switch的参数不能为实型。 華為 1、局部变量能否和全局变量重名? 答:能,局部会屏蔽全局。要用全局变量,需要使用"::" 局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内

汇编语言2008秋季期末考试复习题及参考答案

汇编语言2008秋季期末考试复习题及参考答案 一、填空 1. 十进制数369转换成二进制数为()2,转换成十六进制数为()16. 2. 计算机中的指令由()和(地址码)两部分组成。 3. 8086的地址总线有20根,寻址范围为()字节。 4. 下一条将要执行的指令的地址存放在寄存器()中。 5. 写出IBM PC机的三种子程序返回的指令(RET), (IRET),(IRETD)。 6. 汇编语言源程序需经过()程序汇编,()程序连接才能生成可执行文件。 7. 存储器某单元的地址表示为2314H:4132H,则它的偏移地址=(4132),物理地址=() 8. REP指令前缀与()指令配合使用。 9. 在显示器上查看和修改内存单元的内容可以使用DEBUG的()和()命令。 10. (AL)=BFH,要求屏蔽第0,1两位,则要执行指令();如果要求第0,1位变反,可使用指令() 11. 宏汇编适合于(),()的子功能段使用; 二、选择题 1. 设字长N=16,有符号数7AE9H的补码表示为( ) A.9EA7H B. 76C4H C. 8417H D. 7AE9H 2. 比较有符号数3260H与0B425H的大小关系为( ) A. 相等 B. 小于 C. 大于 D. 不能比较 3. 指令JMP WORD PTR [BX][DI]中转移的目标地址为( ) A.16 d x(DS)+(BX)+(DI)B.16d x(ES)+(BX)+(DI) C.16d x(SS)+(BX)+(DI)D.16d x(CS)+(BX)+(DI) 4. 在指令MOV AX,[1000H]中,源操作数的寻址方式为( ) A.立即寻址B.直接寻址C.段内间接寻址D.寄存器寻址 5. 中断矢量表中存放的是( ) A. 中断类型号 B. 断点地址 C. 中断服务程序 D. 中断服务程序入口地址 6. 8086 的汇编语言指令系统中的条件转移指令可以使程序转移到( ) A. 段内的任何地方 B. 距该指令偏移地址为-32768~+32767的地方 C. 距该指令偏移地址为-128~+127的地方. D. 段外 7. 能定义ASCII码字符串的数据定义语句有( ) A. DB,DW,DD,DQ,DT B. DB,DW,DD C. DB, DW D. DB; 8. 若(AL)=87H,执行ADD AL,0F5H后,S,Z,C,O,P的状态为( ) A.SF=0,ZF=0,CF=1,OF=1,PF=0 B.SF=1,ZF=0,CF=1,OF=0,PF=1 C.SF=0,ZF=0,CF=0,OF=1,PF=0 D.SF=1,ZF=0,CF=1,OF=1,PF=1 9. 比较指令CMP( ) A. 专用于有符号数比较 B. 专用于无符号数比较 C. 专用于串比较 D. 不区分比较的对象是有符号数还是无符号数 10. 数据传送指令对标志位的影响为( ) A.都不影响;B.都影响; C.除了SAHF,POPF,其它均不影响. D.除了控制标志位,其它均不影响 三、判断题 ( )31. 段间调用的子程序必须由伪操作FAR说明为远过程。

汇编语言试题(有答案))

汇编语言试题及参答案 一、填空题 1.ZF标志位是标志结果是否为零的,若结果,ZF为(1),否则ZF为(0)。当ZF为1时,SF为(0) 2.标号可以有两种类型属性。它们是(近程)和(远程) 3.8位无符号整数的表示范围为0--255,写成16进制形式为(0--FFH),8位有符号整数的表示范围为-128--+127,写成16进制形式为(80H--7FH) 4.伪指令DB,GROUP 和NAME 三个标号名字域必须有名字的是(GROUP),不得有名字的是(NAME),可有可无名字的是(DB)。 5.循环程序通常由(循环准备)(循环体)(循环的控制与修改)和循环结果外理四部分构成 6.在数值不达式中,各种运算符可可混合使用,其优先次序规则*,/(高)于+,-;XOR,OR(低)于AND,LT(等)于GT 7. 宏指令定义必须由伪指令(MACRO)开始,伪指令(ENDM)结束,两者之间的语句称为(宏定义体) 8.调用程序与子程序之间的参数传递方法有四种,即堆栈法(约定寄存器法)(约定存储单元法)(向量传递法) 9.分别用一条语句实现下述指明的功能 (1)栈顶内容弹出送字变量AYW(POP AYW) (2)双字变量AYD存放的地址指针送ES和SI(LES SI,AYD) (3)变量AY2类型属性送AH(MOV AH,TYPE AY2) (4)不允许中断即关中断(CLI) (5)将字符串‘HOW ARE YOU!’存入变量AYB(AYB DB“HOW ARE YOU!”) (6)子程序返回调用程序(RET) (7)地址表达式AYY[4]的偏移地址送字变量ADDR(MOV ADDR,OFFSET AYY[4]) (8)AX的内容加1,要求不影响CF(INC AX) (9)BX的内容加1,要求影响所有标志位(ADD BX,1) (10)若操作结果为零转向短号GOON(JZ GOON) 二、单选题 1.IBM PC微机中,有符号数是用(2 )表示的 1.原码2.补码3.反码4.BCD码 2.把汇编源程序变成代码程序的过程是(2 ) 1.编译2.汇编3.编辑4.链接 三、己知:VAR1,VAR2的类型属性分别为字和字节,标号LPFAR的类型属性为FAR。指出下列非法语句的错误原因 1.POP CS(CS不能作目的操作数) 2.INC [BX] ( ) 3.MUL 8( 乘法指令源操作数不能是立即数) 4.JLE LPFAR( ) 5.MOV DB,1800( 立即数不能直接送段寄存器) 6.MOV[DI],VAR1 两个操作数不能同时为存储器操作数 7.SUB AX,VAR2( 操作数不配,AX为字,VAR2为字节) 8.CMP SS AX(段寄存器不能作为运算指令的操作数) 四、简答题

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