文档库 最新最全的文档下载
当前位置:文档库 › C语言 200912选择题(含答案)

C语言 200912选择题(含答案)

C语言 200912选择题(含答案)
C语言 200912选择题(含答案)

2009年12月C语言选择题

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

A.'字'

B."A"

C."ABC"

D.'\x41'

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

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

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

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

D.每行只能写一条语句

50102错误的叙述是( D )。

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

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

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

D.构成C语言源程序的基本单元是算术表达式50103( A )是关于C语言数据类型的正确叙述。

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

B.不允许使用空类型

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

D.数组并不是构造类型

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

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

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

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

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

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

A.< >

B.( )

C.{ }

D.[ ]

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

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

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

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

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

50107一个C语言源程序是由( A )。

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

B.函数组成

C.若干过程组成

D.若干子程序组成

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

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

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

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

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

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

A.录入与编辑

B.查错与编译

C.查错与排错

D.连接与运行

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

A.尖括号"< >"

B.圆括号"( )"

C.花括号"{}"

D.方框号"[ ]"

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

A.语句

B.变量

C.运算符

D.函数

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

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

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

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

D.构成C源程序的基本单位是函数,所有函数名都可以由用户命名

题号:50113下面叙述正确的是(D)。

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

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

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

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

题号:50114下面叙述错误的是(B)。

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

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

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

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

题号:50115(C)是关于C语言数据类型的正确叙述。

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

B.数组不是构造类型

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

D.不允许使用空类型

题号:50116 C源程序中main()函数的位置( C )。

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

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

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

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

题号:50117 C语言的函数体由( B )括起来。

A.( )

B.{ }

C.< >

D.[ ]

题号:50118下面叙述错误的是( D )。

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

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

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

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

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

A.++

B.+=

C.||

D.!=

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

A.struct

B.5f

C._f 0.6

D._for

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

A.整型、实型、逻辑型

B.整型、实型、字符型

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

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

50203( A )为合法的常量。

A.52686L

B.E-7

C.1.2E-2.1

D.'E12'

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

A.-k15

B.int

C.k_5

D.k.jeep

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

A.''\\''

B."\24m"

C."c"

D.'M'

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

A." "

B."s"

C.'efg'

D."26'62"

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

A.原码

B.反码

C.补码

D.BCD码

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

A.E-3

B..2E1

C.1E.5

D.1.5E

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

A.Double

B.unsigned

C.integer

D.Char

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

A.由用户自己定义

B.为2个字节

C.是任意的

D.等于所用计算机的字长50211 Turbo C中,基本数据类型存储空间长度的排列顺序是( A )。

A.char

B.char=int

C.char

D.char=int=long int

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

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

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

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

题号:50213(B )为正确的用户标识符。

A.3_row

B.max_at

C.union

D.min-5

题号:50214 C语言的基本数据类型包括( A )。

A.整型、实型、字符型

B.整型、实型、空类型

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

D.整型、实型、逻辑型

题号:50215( D )为合法的常量。

A.5,326

B.3.21E-6.5

C.'b_k'

D.1.23E+8

题号:50216( D )为正确的变量名。

A.5_pro

B.case

C.else

D.pro_5

题号:50217( C )为正确的字符常量。

A.'bcd'

B.'\084'

C.'@'

D.'165'

题号:50218( A )为非法的字符串常量。

A.'123'

B."case"

C."056"

D." "

50300已知'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

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

A.m*7

B.m*5=8

C.m-=m*6

D.double(-m)

50302语句 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

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

A.1

B.2

C.3

D.0

50304( 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;

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

50306若变量 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)

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

A.x%7

B.x/=a-b

C.a=b=2

D.x=(float)a/b

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

A.(m+n)*=k

B.m=(n==5)

C.k=float(n)/m

D.n%2.5

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

A.10

B.0

C.34

D.24

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

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

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

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

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

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

A.5

B.0

C.3

D.2

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

A.15

B.30

C.75

D.60

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

A.b+=b*3

B.b=*5

C.*b=6

D.b+10=-5

题号:50314若有定义: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

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

A.0

B.3

C.4

D.2

题号:50316( 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;

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

A.0

B.-3

C.-12

D.-6

题号:50318若有定义 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)

50400下列语句中,符合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;

50401( A )是正确的叙述。

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

B.'G' 与"G" 等价

C.5/6 与 5.0/6.0 等价

D.++3与4 等价50402下面叙述中,错误的是( D )。

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

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

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

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

50403( C )是正确的叙述。

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

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

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

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

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

A.0

B.10

C.9

D.8

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

A.y=x%3

B.y = x/3

C.y =(++x)/3

D.y=8-(--x)

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

A.0

B.3

C.1

D.2

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

A.10

B.1

C.1.25

D.0

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

A.2

B.3

C.4

D.6

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

A.2

B.5

C.0

D.27

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

A.9

B.7

C.8

D.5

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

A.单目运算符

B.四目运算符

C.双目运算符

D.三目运算符

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

题号:50413下面叙述正确的是( B )。

A.2/3 与 2%3 等价

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

C.++2 与 3 等价

D.++2与--3 等价

题号:50414下面叙述错误的是( A )。

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

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

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

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

题号:50415下面叙述正确的是( A )。

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

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

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

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

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

A.18

B.15

C.12

D.10

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

A.5 6

B.6 5

C.5 5

D.6 6

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

A.6

B.8

C.7

D.3

50500以下程序运行时,若从键盘输入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

50501若已定义 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) ;

50502若已定义 double y; 拟从键盘输入一个值赋给变量y,则正确的函数调用是( C )。A.scanf("%d",&y) ; B.scanf("%7.2f",&y) ; C.scanf("%lf",&y) ; D.scanf("%ld",&y) ; 50503已有定义 char s; 使用scanf( )函数输入一个字符给变量s,不正确的函数调用是( D )。

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

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

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

D.scanf("%lf",&s) ; 50504函数putchar( ) 的功能是向终端输出( A )。

A.一个字符

B.多个字符

C.一个关系表达式

D.一个实型变量值

50505若已定义 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

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

A.4321432143211231231232121

B.432112321

C.4321+123+21

D.432+123+021

50507已有如下定义和输入语句,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

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

int a=1; printf("%d, %d, %d\n", a, ++a, a++);

A.3,3,1

B.1, 2, 2

C.1, 2, 3

D.3, 2, 1

50509以下程序的运行结果是( 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

50510若已定义: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);

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

A.字符或字符型变量值

B.整型变量表达式值

C.实型变量值

D.字符串

50512若已定义: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);

题号:50513若有定义 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); 题号:50514只能向终端输出一个字符的是( C )。

A.printf()函数

B.scanf()函数

C.getchar()函数

D.putchar()函数

题号:50515若有语句 int a; char c; scanf("%3d%c",&a,&c); 为将整数135赋给a,

字符'6'赋给c,正确的数据输入方式是( B )。(说明:代表换行,__代表空格)

A.135__6

B.1356

C.1356

D.135__6__

题号:50516 getchar()函数的功能是获取终端输入的( B )。

A.多个字符

B.一个字符

C.一个实型变量值

D.一个整型变量表达式

题号:50517若有定义 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);

题号:50518若有定义: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

50600有以下程序:

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

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

A.1

B..t.

C.0

D..f.

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

A.1

B.大于0的数

C.非0的整数

D.非0的数

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

A..t.

B.1

C..f.

D.0

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

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

B.100<= s<300

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

D.(s>=100) and (s<300) 50605若定义 int a=2,b=3; 则表达式 !a||b 的值为( B )。

A.0

B.1

C.2

D.3

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

A.变量i的值

B.变量j的值

C.0

D.1

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

A.x%2==1

B.!(x%2==0)

C.!(x%2)

D.x%2

50608若有定义: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)

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

A.1

B.0

C.2

D.4

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

A.0

B.1

C.2

D.3

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

A.<=

B.&&

C.||

D.!

50612执行以下语句后,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

题号:50613 x的值在-20至-5之间为“真”,否则为“假”的正确逻辑表达式为( B )。A.-20-20 && x<-5 C.!(x>-20) && !(x<-5) D.-5

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

A.a%2==1

B.!(a%2)

C.a%2

D.!(a%2==0)

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

A.2

B.1

C.0

D.-1

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

A.!((x

B.x>y || x

C.x<=y

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

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

A.1

B.0

C.2

D.3

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

A.a!=0

B.a==0

C.a=0

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

50700以下程序运行后,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

50701已定义 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)

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

A.c=\028

B.c=(c++)%4

C.c+1=66

D.c+=127--

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

A.2*m=m++

B.m=int(-3.2)

C.m%3

D.m=m-m=m-5

50704设已定义 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

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

A.6.375

B.6.75

C.5.75

D.5.5

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

A.6

B.1

C.9

D.0

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

A.7.5

B.7

C.6

D.5

50708若有定义:int x=8; float y=130;char z='A'; 则表达式x+z%(int)y的值是( C )。

A.运行时产生错误信息

B.8

C.73

D.8.5

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

A.3

B.4

C.4.5

D.5

50710若有定义:float 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)

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

A.double

B.int

C.char

D.void

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

A.1.5

B.1

C.4

D.4.5

题号:50713下列运算符中优先级最低的是( A )。

A.=

B.!

C.>

D.*

题号:50714若有定义: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)

题号:50715若有定义: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'

题号:50716若有定义: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

题号:50717若有定义: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

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

A.0 0

B.1 1

C.0 1

D.1 0

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

int x=3;

do{ printf("%3d, ", x-=2 );

} while(!(--x));

A.1

B.30

C.死循环

D.1, -2

50801以下程序运行时,若从键盘输入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

50802以下程序的运行结果是( 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.-1

C.7

D.1

50803对于整型变量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;

50804以下程序运行的结果是( 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

50805若已定义 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=1

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

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

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

int a=3,b=2;

int k;

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

A.0

B.1

C.2

D.3

50807以下程序的运行结果是( 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

50808以下程序的运行结果是( 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

50809以下程序的运行结果是( 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

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

A.8

B.9

C.10

D.0

50811若有定义: 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 1

C.3

D.1

50812以下条件语句中(其中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;

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

int a,y=10; scanf("%d",&a);

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

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

A.10

B.11

C.16

D.15

题号:50814以下程序的运行结果是( 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

题号:50815若有定义: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;

题号:50816以下程序段的运行结果是(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

题号:50817以下程序段的运行结果是( 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

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

A.4

B.3

C.6

D.5

50900下列程序段中,非死循环的是( 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(;;)

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

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

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

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

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

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

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

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

C.结束本次循环

D.暂停程序的运行

50903以下程序段运行后,循环体中的 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次

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

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

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

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

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

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

int i=8,a=0;

for ( ;i<8;i++) a+= i;

A.0次

B.1次

C.8次

D.无限

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

int i=1,a=0;

for( ;i<3;i++)

{ continue;

a+=i; }

A.6

B.3

C.0

D.5

50907有以下程序:

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

C.111223

D.123

50908以下程序的运行结果是( 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

50909以下程序的运行结果是( 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

50910以下程序的运行结果是( 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

50911以下程序的运行结果是( 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

50912以下程序运行时,循环体的执行次数是( 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

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

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

B.while(x=1) ;

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

D.for( ; ;i+=2) ; 题号:50914下面叙述正确的是( D )。

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

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

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

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

题号: 50915 以下程序段运行后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

题号:50916以下程序段运行后x的值为( B )。

int i=0,x=2;

while(i++<=5)

{x+=2; }

A.10

B.14

C.12

D.8

题号:50917若有定义: 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++; }

题号:50918以下程序段运行后x的值为( D )。

int i=0,x=0;

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

{x+=3;}

A.15

B.6

C.12

D.9

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

A.19

B.16

C.18

D.14

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

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

B.字符串常量

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

D.任何类型的表达式

51002( 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];

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

A.arr[0]

B.arr[1]

C.arr[10-1]

D.arr[7+3]

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

A.0

B.2

C.1

D.3

51005以下程序段运行后,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

51006( 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’;

51007若有以下程序:

void main( )

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

r=s;

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

则( A )。

A.执行时输出:ajskdl

B.执行时输出:a

C.执行时输出:aj

D.编译不通过

51008下面程序段的运行结果是( 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

51009下面程序段的运行结果是( 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

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

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

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

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

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

51011以下程序段的运行结果是( 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

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

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

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

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

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

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

A.a[9+i]

B.a[10-i]

C.a[10]

D.a(7)

题号:51014( 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]; 题号:51015若有定义:int arr[15],n=5; 无法正确引用arr数组元素的是( C )。

A.arr[0]

B.arr[n]

C.arr[10+n]

D.arr[15-n]

题号:51016以下程序段运行后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

题号:51017以下程序段运行后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

题号:51018下面叙述错误的是( C )。

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

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

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

D.C语言规定可逐个引用数组元素但不能一次引用整个数组51100以下程序段的运行结果是( 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.**********

********

******

****

51101以下程序段执行后输出的结果是( 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

51102以下程序段执行后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

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

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

A.3

B.4

C.0

D.1

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

A.7

B.8

C.9

D.10

51106以下程序段运行后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

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

A.a[0][1/2]

B.a[2][1]

C.a[2][3]

D.a[1][3]

51108在以下数组定义中,错误的是( 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};

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

A.1

B.2

C.3

D.4

51110以下程序段运行后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

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

A.数组a包含3个元素

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

C.数组a的行数为1

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

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

A.3

B.4

C.5

D.6

题号:51113以下程序段的运行结果是( 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.1

题号:51114以下程序段运行后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

题号:51115以下( 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}};

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

A.4

B.2

C.1

D.3

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

A.5

B.4

C.3

D.2

题号:51118以下程序段运行后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

51200设有下列语句,则( 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))

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

A.s1=s2;

B.strcpy(s2,s1);

C.strcpy(s1,s2);

D.s1="Science";

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

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

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

printf("%s",str[0]);

A.abcd

B.ab

C.abcd0

D.abcd0f

51203有如下定义:char str[10]={ "National"};则分配给数组str的存储空间是(B)个字节。

A.11

B.10

C.9

D.8

51204以下程序段运行后输出结果是( C )。

char a[]="country";

char b[]="game";

strcpy(a,b);

printf("%c",a[3]);

A.n

B.u

C.e

D.m

51205以下程序段运行后输出结果是( A )。

char s[]="info\0mis";

printf("%d",strlen(s));

A.4

B.5

C.8

D.9

51206以下程序段运行后a的值为( D )。

int a=2;

char s1="passion",s2=s1;

a=strcmp(s1,s2);

A.-1

B.2

C.1

D.0

51207以下对C语言字符数组描述中,错误的是( B )。

A.可以用strlen函数计算字符数组中字符串的长度

B.可以在赋值语句中通过赋值运算符"="对字符数组整体赋值

C.存放在字符数组中的字符串,以'\0'作为该字符串结束标志

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

51208以下程序段运行后,屏幕的输出结果是( B )。

char str[80];

strcpy(str,"computer");

printf("%d",strlen(str));

A.7

B.8

C.9

D.80

51209若有定义:char str1[6]="ABCDE",*ps,*str2="FEDCBA";( C )是错误的。

A.strcpy(str2,str1);

B.表达式strcmp(str1,str2)的值小于0

C.str1=str2;

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

51210已有定义 char str1[15]={"computer"},str2[15];则语句用法正确的是( C )。

A.str2=str1;

B.str2="science";

C.scanf("%s",str2);

D.printf("%s",&str1);

51211设已定义: char str1[20]="Hello ",str2[20]="world!"; 若要形成字符串"Hello world!",正确语句是( B )。

A.strcpy(str1,str2);

B.strcat(str1,str2);

C.strcpy(str2,str1);

D.strcat(str2,str1); 51212若有字符数组a[80]和b[80],则以下输入语句正确的是( C )

A.gets(a,b)

B.scanf("%c%c",&a,&b);

C.scanf("%s%s",a,b)

D.gets("a"),gets("b"); 题号:51213若有定义:char str1[10],str2[10]="Fujian"; ,能将字符串"Fujian"赋给数组str1的正确语句是( B )。

A.str1="Fujian";

B.strcpy(str1,str2);

C.strcpy(str2,str1);

D.strcopy(str1,str2); 题号:51214以下程序段的运行结果是( D )。

char str[3][2]={ 'a','b','c','\0','e','f'};printf("%s",str[0]);

A.a

B.abcef

C.abc\0ef

D.abc

题号:51215以下程序段的运行结果是( C )。

char str[]={ "FuJian"};printf("%d",strlen(str));

A.9

B.7

C.6

D.8

题号:51216以下程序段的运行结果是( B )。

char a[]="abcdef";char b[]="xyz";

strcpy(a,b); printf("%c",a[2]);

A.c

B.z

C.b

D.y

题号:51217以下程序段的运行结果是( C )。

char a[]="abc ";char b[]="xyz";char c[10];

strcpy(c,a);strcat(c,b); printf("%s",c);

A.abc

B.abc xyz

C.xyz

D.xyzabc

题号:51218以下程序段运行后a的值为( B )。int a=2;a=strcmp("miss","miss");

A.1

B.0

C.-1

D.true

51300设有下列语句: char str1[]="string",str2[8],*str3,*str4="string";则( A )是对库函数strcpy的不正确调用。此函数用来复制字符串。

A.strcpy(str3,"HELLO3");

B.strcpy(str2,"HELLO2");

C.strcpy(str1,"HELLO1");

D.strcpy(str4,"HELLO4");

51301用数组名作为函数的实参时,错误的说法是( A )。

A.定义形参数组时,元素的个数必须与实参相同

B.可以使用数组名作为形参

C.实参传递给形参的值是数组的首地址

D.可以使用指针变量作为形参

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

int fun(int a[4][4])

{ int i;

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

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

printf("\n");}

main()

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

fun(a);}

A.1 9 0 5

B.2 0 0 0

C.2 0 0 8

D.2 0 0 9

51303自定义函数中若缺省函数值类型,则隐含的类型是( A )。

A.int

B.long

C.float

D.double 51304以下程序运行后输出结果是( C )。

#include

int fun(int a, int b)

{ return(a-b); }

main()

{ int x=5,y=3,k;

k=fun(x,y);

printf("%d-%d=%d\n",x,y,k); }

A.0

B.x-y=2

C.5-3=2

D.2

51305以下程序运行后输出结果是( D )。

#include

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

int fun(int a, int b)

{ int c;

c=a>b?a:b;

return(c); }

main()

{ int a=6;

printf("%d",fun(fun(a,b),c)); } A.5 B.3,5 C.6,5 D.6

51306以下程序运行后输出结果是( C )。void fun(int i)

{ int m=2;

m=i++;

printf("%d ",m);}

main()

{ int m=7,n=5;

fun(n);

printf("%d",m);}

A.5 5

B.6 6

C.5 7

D.6 7

51307若有函数定义:

int func()

{static int m=0;

return m++; }

以下程序段运行后屏幕输出为( C )。

int i;

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

func();

printf("%d",func());

A.0

B.1

C.4

D.5

51308下面程序的输出结果是( B )。

#include

int num=10;

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语言基础练习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)); 上面程序片段的输出结果是_______.

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),内部函数应该在当前源文件中说明和定义。对

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语言面试题(经典全)

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

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.前言 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可以初始化一个联合吗?

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

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、局部变量能否和全局变量重名? 答:能,局部会屏蔽全局。要用全局变量,需要使用"::" 局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内

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.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语言大赛题目精选(带答案)

第1题歌手大赛问题 题目: 青年歌手参加歌曲大奖赛,有10个评委进行打分,试编程求这位选手的平均得分。 3种方法: 分别要求使用到排序,数组,函数,指针。 分析: 这道题的核心程序是排序,将评委打的10个分数利用数组按增序(或降序)排列,计算数组中除了第一个和最后一个分数以外的数的平均分 答案: #include double Aver(int p[],int count) //求出结果,p为整型数组,count为数组大小{double result=0; for(inti=0;i

for(int k=1;k

(完整版)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

相关文档
相关文档 最新文档