当前位置:文档之家› C语言选择题(1-4章期末复习)

C语言选择题(1-4章期末复习)

C语言选择题(1-4章期末复习)
C语言选择题(1-4章期末复习)

第1章

1.以下叙述不正确的是()。

A、C程序的基本组成单位是函数

B、在C程序中,注释说明只能位于一条语句的后面

C、一个C源程序必须包含一个main函数

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

2.C语言的注释定界符是()。

A、\* *\

B、{ }

C、[ ]

D、/* */

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

A、必须在最开始

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

C、必须在最后

D、可以任意

4.一个C程序的执行是从()。

A、本程序文件的第一个函数开始,到本程序main函数结束

B、本程序的main函数开始,到main函数结束

C、本程序的main函数开始,到本程序文件的最后一个函数结束

D、本程序文件的第一个函数开始,到本程序文件的最后一个函数结束

5.以下叙述中正确的是()。

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

B、分号是C语句之间的分隔符,不是语句的一部分

C、花括号“{“和”}”只能作为函数体的定界符

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

6.以下叙述正确的是()。

A、在对一个C程序进行编译的过程中,可发现注释中的拼写错误

B、C语言本身没有输入输出语句

C、在C程序中,main函数必须位于程序的最前面

D、C程序的每行中只能写一条语句

7.C语言源程序的基本单位是()。

A、子程序

B、过程

C、函数

D、标识符

8.下列标识符中,不合法的C语言用户自定义标识符是()。

A、printf

B、sin

C、enum

D、_

9.下列四个选项中,均是C语言关键字的选项是()。

A、if struct type

B、switch typedef continue

C、signed union scanf

D、auto enum include

10.以下叙述中错误的是()

A、用户所定义的标识符应尽量做到"见名知意"

B、用户所定义的标识符允许使用关键字

C、用户定义的标识符中,大、小写字母代表不同标识

D、用户所定义的标识符必须以字母或下划线开头

11.下列字符序列中,可用作C标识符的一组字符序列是()。

A、#md,&12x,month,student_n!

B、D56,r_1_2,name,_st_1

C、S.b,sum,average,_above

D、class,day,lotus_1,2day

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

A、_123 temp int

B、A P_0 do

C、b-a goto int

D、float la0 _A

13.下列四组选项中,均不是C语言关键字的选项是()。

A、file IF type

B、include scanf case

C、while go pow

D、getc char printf

14.下列字符序列中,不可用作C语言标识符的是()。

A、symbol

B、#ab

C、a_1

D、b70

15.C语言中不合法的字符串量是()

A、”\121”

B、’y=’

C、”ABCD\x6d”

D、”\n\n”

16.下列数据中,为字符串常量的是()。

A、$abc

B、"house"

C、A

D、How do you do.

17.C语言中不合法的字符常量是()

A、’\65’

B、’\xff’

C、’\028’

D、’&’

18.设有语句char a= ‘\172’;,则变量a()

A、说明不合法

B、包含2个字符

C、包含1个字符

D、包含3个字符

答案:C

19.以下常量中,能够代表逻辑“真”值的常量是()。

A、‘\0'

B、'0'

C、0

D、NULL

20.以下所列的C语言常量中,错误的是()。

A、0xFF

B、2L

C、'\72'

D、1.2e0.5

21.以下数据中,不正确的数值或字符常量是()。

A、10

B、0xff00

C、8.9e1.2

D、82.5

22.以下数据中,不正确的数值或字符常量是()。

A、0xaa

B、66

C、c

D、50

23.与十进制数97不等值的字符常量是()

A、’\101’

B、’\x61’

C、’\141’

D、’a’

24.已知大写字母A的ASCII码是65,小写字母a的ASCII码是97,则用八进制表示的字符常量'\101'是()

A、非法的常量

B、字符a

C、字符e

D、字符A

25.不合法的八进制数是()

A、01

B、0

C、07700

D、028

26.要将字符a赋给变量c,下列语句中正确的是()。

A、c="a";

B、C='97';

C、c='a';

D、c="97";

27.设C语言中,int类型数据占2个字节,则long类型数据占()。

A、8个字节

B、2个字节

C、1个字节

D、4个字节

28.设C语言中,int类型数据占2个字节,则short类型数据占()。

A、1个字节

B、2个字节

C、8个字节

D、4个字节

29.以下关于long、int和short类型数据占用内存大小的叙述中正确的是()

A、由C语言编译系统决定

B、均占4个字节

C、由用户自己定义

D、根据数据的大小来决定所占内存的字节数

30.C语言中,字符(char)型数据在微机内存中的存储形式是()

A、反码

B、EBCDIC码

C、ASCII码

D、补码

31.C语言中,char类型数据占()。

A、2个字节

B、8个字节

C、4个字节

D、1个字节

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

A、0—255

B、0—2147483647

C、0—32767

D、0--65535

33.C语言中,double类型数据占()。

A、4个字节

B、1个字节

C、2个字节

D、8个字节

34.设有说明:char w; int x; float y; double z; 则表达式w*x+z-y值的数据类型为()

A、float

B、int

C、double

D、char

35.C语言中要求对变量作强制定义的主要理由是()。

A、便于移植

B、便于确定类型和分配空间

C、便于编辑预处理程序的处理

D、便于写文件

36.若变量已正确定义且 k 的值是 4,计算表达式 ( j =4, k--) 后,j和k的值为()

A、j=3, k=3

B、j=4, k=4

C、j=3, k=4

D、j=4, k=3

37.设有 int x=11; 则表达式 (x++ * 1/3) 的值是()。

A、3

B、4

C、11

D、12

38.以下选项中,与k=n++完全等价的表达式是()。

A、k=++n

B、k+=n+1

C、k=n,n=n+1

D、n=n+1,k=n

39.执行下列语句后变量x和y的值是()。y=10;x=y++;

A、x=10,y=10

B、x=11,y=10

C、x=11,y=11

D、x=10,y=11

40.经过以下语句定义后,表达式z+=x>y?++x:++y的值为()。 int x=1,y=2,z=3;

A、6

B、3

C、2

D、5

41.设 int x=1, y=1; 表达式(!x||y--)的值是()。

A、-1

B、0

C、2

D、1

42.若变量已正确定义并赋值,下面符合C语言语法的表达式是()。

A、int 18.5%3

B、a:=b+1

C、a=a+7=c+b

D、a=b=c+2

答案:D

43.如果p是一个整型数,下列表达式始终为真的是( )。

A、p && p

B、p || p

C、p && !p

D、p || !p

44.能正确表示逻辑关系:" a≥10或a≤0 "的C语言表达式是()

A、a>=0 && a<=10

B、a>=10 or a<=0

C、a>=10 && a<=0

D、a>=10 || a<=0

45.以下运算符中,优先级最高的运算符是()。

A、+

B、*=

C、>=

D、(类型)

46.下列运算符中优先级别最高的是( )

A、!

B、%

C、-=

D、&&

47.以下关于运算符优先顺序的描述中正确的是()。

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

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

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

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

48.以下的选择中,正确的赋值语句是()。

A、y=int(x)

B、j++

C、a=b=5;

D、a=1,b=2

49.以下非法的赋值语句是( )

A、j++;

B、x=j>0;

C、n=(i=2,++i);

D、++(i+1);

50.以下不符合C语言语法的赋值语句是()。

A、a=b=5;

B、a=1,b=2

C、++j;

D、y=(a=3,6*5);

51.如果int a=2,b=3,c=0,下列描述正确的是( )

A、a||(b=c)执行后b的值为0

B、a>b!=c和a>(b!=c)的执行顺序是一样的

C、a&&b>c的结果为假

D、!a!=(b!=c)表达式的值为1

52.已有定义:int x=3,y=4,z=5;,则表达式!(x+y)+z-1 && y+z/2的值是( )

A、6

B、1

C、0

D、2

53.若给定条件表达式(M)?(a++):(a--),则其中表达式M()。

A、和(M!=1)等价

B、和(M==1)等价

C、和(M!=0)等价

D、和(M==0)等价

54.用下列语句定义a,b,c,然后执行b=a、c='b'+b,则b,c的值是()。

long a=3;

int b; char c;

A、2和101

B、3和101

C、3和100

D、3 和99

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

A、不确定

B、double

C、int

D、float

56.若a为int类型,且其值为3,则执行完表达式a+=a-=a*a后,a的值是()。

A、9

B、-12

C、6

D、-3

57.若希望当A的值为奇数时,表达式的值为“真”,A的值为偶数时,表达式的值为“假”,则以下不能满足

要求的表达式是()。

A、!(A%2)

B、A%2==1

C、!(A%2==0)

D、A%2

58.判断char型变量cl是否为小写字母的正确表达式是()。

A、(cl>=a)&&(cl<=z)

B、'a'<=cl<='z'

C、('a'>=cl)||('z'<=cl)

D、(cl>='a')&&(cl<='z')

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

A、7

B、2

C、6

D、8

60.设a、b、c、d、m、n均为int型变量,且a=5、b=6、c=7、d=8、m=2、n=2,则逻辑表达式(m=a>b)&&(n=c>d)

运算后,n的值为()。

A、3

B、0

C、1

D、2

61.若已定义x和y为double类型,则表达式x=1,y=x+3/2 的值是()。

A、1

B、2.0

C、2.5

D、2

62.已知year为整型变量,不能使表达式(year%4==0&&year%100!=0)||year%400==0的值为“真”的数据是

()。

A、1992

B、1990

C、2000

D、1996

63.能正确表示逻辑关系:"10≥a≥0"的C语言表达式是()。

A、a>=0||a<=10

B、a>=10‖a<=0

C、a<=10 && a>=0

D、a>=10&&a<=0

64.下列各m的值中,能使m%3==2&&m%5==3&&m%7==2为真的是()。

A、6

B、17

C、23

D、8

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

A、3.500000

B、0.000000

C、2.750000

D、2.500000

第2章

1. b reak语句的正确的用法是()。

A、无论在任何情况下,都中断程序的执行,退出到系统下一层。

B、在多重循环中,只能退出最靠近的那一层循环语句。

C、跳出多重循环。

D、只能修改控制变量。

2.对于以下程序片段,描述正确的是()。

int x = -1;

do {

x = x * x;

}while(!x);

A、是死循环 B. 循环执行两次 C. 循环执行一次 D. 有语法错误

3.两次运行下面的程序,如果从键盘上分别输入6和3,则输出结果是()。

int x;

scanf(“%d”,&x);

if(x++>5)

printf(“%d”,x);

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

A、7和5

B、6和3

C、7和4

D、6和4

4. 为了避免嵌套的条件分支语句if-else的二义性,C语言规定:C程序中的else总是与()组成配对关

系。

A、缩排位置相同的if

B、在其之前未配对的if

C、在其之前未配对的最近的if

D、同一行上的if

5.下列程序段的输出结果是()

int x=0;

while(++x<3)

printf("%4d",x);

A、4

B、0 1 2

C、1 2

D、3

6.循环结束后,count 的值是()

count=1;

while(count<=145)

{

a=a+7;

count++;

}

A、1

B、144

C、145

D、146

7.有如下程序片段:

int i = 0;

while(i++ <= 2);

printf("%d", i);

则正确的执行结果是( )

A、2

B、3

C、4

D、以上都不对

8.在下面的条件语句中(其中S1和S2表示C语言的语句),只有一个在功能上与其他3条语句不等价,

它是()

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;

9.执行下列代码后的输出是( ).

int a=1,b=0;

switch (a){

case 1:

switch(b) {

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

break;

case 1: printf("**1**");

break;

}

case 2:

printf("**2**");

break; }

A、**0**

B、**0****2**

C、**0****1****2**

D、运行出错

10.执行下列语句后,sum 的值是()。

sum=0;

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

sum=sum+2*count;

A、28

B、18

C、10

D、30

第3章

===================================================================================

1.以下不正确的说法是:C语言规定( B )。

A、形参应与其对应的实参类型一致

B、形参可以是常量,变量或表达式

C、形参应与其对应的实参个数一致

D、实参可以是常量,变量或表达式

2.下面叙述中不正确的是( B )

A、函数可以返回一个值,也可以什么值也不返回

B、空函数不完成任何操作,所以在程序设计中没有用处

C、声明函数时必须明确其参数类型和返回类型

D、用户若需调用标准库函数,调用前要使用预编译命令将该函数所在文件包括到用户源文件中

3.以下函数调用语句中实参的个数是( D )。 exce((v1,v2),(v3,v4,v5),v6);

A、6

B、5

C、4

D、3

4.以下函数调用语句中,含有的实参个数是 func( (exp1, exp2), (exp3, exp4, exp5));

A、1

B、5

C、2

D、4

5.若已定义的函数有返回值,则以下关于该函数调用的叙述中错误的是()。

A、函数调用可以作为一个函数的实参

B、函数调用可以出现在表达式中

C、函数调用可以作为一个函数的形参

D、函数调用可以作为独立的语句存在

6.函数的形式参数隐含的存储类型说明是()。

A、static

B、register

C、extern

D、auto

7.C语言规定,函数返回值的类型是由()。

A、调用该函数时的主调函数类型所决定

B、return语句中的表达式类型所决定

C、调用该函数时系统临时决定

D、在定义该函数时所指定的函数类型所决定

8.关于return语句,下列正确的说法是()。

A、可以在同一个函数中出现多次

B、使用return语句只能返回整型数据

C、必须在每个函数中出现

D、只能在除主函数之外的函数中出现一次

9.以下正确的说法是:在C语言中()。

A、实参和与其对应的形参各占用独立的存储单元

B、形参是虚拟的,不占用存储单元

C、只有当实参和与其对应的形参同名时才共占用存储单元

D、实参和与其对应的形参共占用一个存储单元

10.下面叙述中错误的是()

A、在其它函数中定义的变量在主函数中也不能使用

B、主函数中定义的变量在整个程序中都是有效的

C、形式参数也是局部变量

D、复合语句中定义的变量只在该复合语句中有效

11.C语言中不可以嵌套的是()。

A、选择语句

B、循环语句

C、函数调用

D、函数定义

12.C语言源程序文件经过C编译程序编译连接之后生成一个后缀为( )的可执行文件

A、.obj

B、.exe

C、.c

D、.bas

13.C语言中,如果函数不需要返回值,函数类型应该定义为()。

A、double

B、int

C、void

D、float

14.若调用一个函数,且此函数中没有return语句,则正确的说法是:该函数()。

A、没有返回值

B、返回若干个系统默认值

C、返回一个不确定的值

D、能返回一个用户所希望的值

15.C语言规定:简单变量做实参时,它和对应形参之间的数据传递方式是()。

A、由实参传给形参,再由形参传回给实参

B、由用户指定的传递方式

C、单向值传递

D、地址传递

16.下面所列举的函数名正确且具有良好风格的是( )。

A、abcde()

B、GetNumber()

C、find@()

D、gotofirstline()

17.C语言程序中必须有的函数是()。

A、#include "stdio.h"

B、main

C、printf

D、scanf

18.C语言程序中,若对函数类型未加显式说明,则函数的隐含说明类型为()。

A、int

B、void

C、char

D、double

19.以下正确的描述是:在C语言程序中()。

A、函数的定义可以嵌套,但函数的调用不可以嵌套

B、函数的定义不可以嵌套,但函数的调用可以嵌套

C、函数的定义和函数的调用均可以嵌套

D、函数的定义和函数的调用均不可以嵌套

20.C语言中函数调用的方式有()。

A、函数调用作为语句或函数表达式两种

B、函数调用作为语句一种

C、函数调用作为语句、函数表达式或函数参数三种

D、函数调用作为函数表达式一种

21.对于返回值是void类型的函数,调用时不可作为()。

A、以上答案都不对

B、if语句的内嵌语句

C、循环体里的语句

D、表达式的一部分参与计算

22.对于建立函数的目的,正确的说法是()

A、提高程序的执行效率

B、减少程序的篇幅

C、减少程序文件所占的内存

D、提高程序的可读性

23.以下叙述正确的是()

A、C程序中各函数之间允许直接递归调用不允许间接递归调用

B、C程序中各函数之间不允许直接递归调用允许间接递归调用

C、C程序中各函数之间不允许直接递归调用也不允许间接递归调用

D、C程序中各函数之间既允许直接递归调用也允许间接递归调用

24.执行下面程序后,输出结果是()。

main()

{ int a=45,b=27,c=0;

c=max(a,b);

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

}

int max(int x,int y)

{ int z;

if(x>y) z=x;

else z=y;

return(z);

}

A、18

B、27

C、45

D、72

25.以下程序的输出结果为()。

main()

{int a=1,b=2,c=3,d=4,e=5;

printf("%d\n",func((a+b,b+c,c+a),(d+e)));

}

int func(int x,int y)

{ return(x+y); }

A、15

B、9

C、13

D、函数调用出错

26.下列存储类别中,()的可见性与生存期不一致。

A、外部变量

B、自动变量

C、静态变量 D. 寄存器变量

27.以下函数的类型是()。

fff(float x)

{ return 5; }

A、无法确定

B、int类型

C、与参数x的类型相同

D、void 类型

28.下列说法不正确的是()。

A、在一个函数内部,可以在复合语句中定义变量,这些变量只在复合语句中有效

B、形式参数是局部变量

C、不同函数中,可以使用相同名字的变量

D、主函数main中定义的变量在整个文件或程序中有效

29.以下关于变量beta的说法正确的是( )。

void fun(int a)

{

static int beta=25;

}

A、当首次调用函数时被初始化一次。

B、每次调用函数时都要进行初始化。

C、在函数中不能改变它的值。

D、A和C都对

30.全局变量的定义不可能在()。

A、函数内部

B、文件外面

C、最后一行

D、函数外面

31.以下不正确的说法是:C语言规定()。

A、实参可以为任何类型

B、形参可以是常量,变量或表达式

C、形参应与其对应的实参类型一致

D、实参可以是常量,变量或表达式

32.在一个C源程序文件中,若要定义一个只允许本源文件中所有函数使用的全局变量,则该变量需要使用的存

储类型是()

A、static

B、register

C、auto

D、extern

33.以下对C语言函数的描述中,正确的是()。

A、C函数既可以嵌套定义又可以递归调用

B、C程序必须由一个或一个以上的函数组成

C、函数必须有返回值,否则不能使用函数

D、C程序中有调用关系的所有函数必须放在同一个程序文件中

34.以下正确的函数原型为( )。

A、func (int x ; int y);

B、void (x , y);

C、void (int x , y);

D、void func (int , int);

35.有如下函数原型和变量定义:void fix(int, float &);

int someInt;

float someFloat;

下列最适合的函数调用是( )。

A、fix(24,6.85);

B、sumeFloat=0.3*fix(someInt,6.85);

C、fix(somInt, someFloat);

D、以上都不对

36.使用重载函数编程序的目的是( )。

A、使用相同的函数名调用功能相似的函数

B、共享程序代码

C、提高程序的运行速度

D、节省存储空间

37.C++中,关于参数默认值的描述正确的是( )。

A、只能在函数定义时设置参数默认值

B、设置参数默认值时,应当全部设置

C、设置参数默认值时,应当从右向左设置

D、设置参数默认值后,调用函数不能再对参数赋值

38.已知程序中已经定义了函数test,其原型是int test(int, int, int);则下列重载形式中错误的是

()

A、char test(int, int, int);

B、double test(int, int, double);

C、int test(int, int);

D、float test(int, int, float=3.5F);

39.以下描述中,正确的是()。

A、预处理是指完成宏替换和文件包含中指定的文件的调用

B、预处理指令只能位于C源文件的开始

C、C源程序中凡是行首以#标识的控制行都是预处理指令

D、预处理就是完成C编译程序对C源程序第一遍扫描,为编译词法和语法分析作准备

40.以下程序的输出结果是()

#define MIN(x, y) (x) < (y) ? (x) : (y)

main()

{ int i , j, k;

i = 10; j = 15;

k = 10 * MIN(i, j);

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

}

A、10

B、150

C、15

D、100

41.下列程序运行结果为:()

#define P 3

#define S(a) P*a*a

main()

{int ar;

ar=S(3+5);

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

}

A、192

B、25

C、29

D、27

42.C程序中的宏展开是在()。

A、编译前预处理时进行的

B、编辑时进行的

C、编译时进行的

D、程序执行时进行的

43.宏定义#define PI 3.14中的宏名PI代替()

A、不确定类型的数

B、一个单精度实数

C、一个字符串

D、一个双精度实数

第4章

1.int a[4]={5,3,8,9};其中 a[3]的值为( )。

A、5

B、3

C、8

D、9

2.以下对一维整型数组a的正确说明是()。

A、int n; scanf("%d",&n); int a[n];

B、#define SIZE 10 (换行) int a[SIZE];

C、int a(10);

D、int n=10,a[n];

3.若有以下说明,则数值为 4 的表达式是( )。

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

A、a[g-c]

B、a[4]

C、a['d'-'c']

D、a['d'-c]

4.数组定义为 int a[3][2]={1,2,3,4,5,6},值为6的数组元素是( )。

A、a[3][2]

B、a[2][1]

C、a[1][2]

D、a[2][3]

5.若用数组名作为函数调用时的实参,则实际上传递给形参的是( )。

A、数组的第一个元素的值

B、数组的首地址

C、数组中全部元素的值

D、数组元素的个数

6.以下()能将数组元素初始化为10,20和30?

A、int data[3]={10,20,30};

B、int data[ ]={10,20,30};

C、int data[3]={10 20 30};

D、A和B都可以

7.对以下说明语句 int a[10]={6,7,8,9,10}; 的正确理解是()。

A、将5个初值依次赋给a[1]至a[5]

B、将5个初值依次赋给a[6]至a[10]

C、因为数组长度与初值的个数不相同,所以此语句不正确

D、将5个初值依次赋给a[0]至a[4]

8.int a[10]; 给数组a的所有元素分别赋值为1、2、3、……的语句是()。

A、for(i=1;i<11;i++)a[0]=1;

B、for(i=1;i<11;i++)a[i]=i;

C、for(i=1;i<11;i++)a[i+1]=i;

D、for(i=1;i<11;i++)a[i-1]=i;

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

A、a(5)

B、a[3,5]

C、a[10-10]

D、a[10]

10.假定int类型变量占用两个字节,其有定义:int x[10]={0,2,4};,则数组x在内存中所占字节数

是()。

A、10

B、3

C、20

D、6

11.下列说法中错误的是( )

A、数组的名称其实是数组在内存中的首地址

B、一个数组只允许存储同种类型的变量

C、如果在对数组进行初始化时,给定的数据元素个数比数组元素个数少时,多余的数组元素会被自动初始化为最后一个给定元素的值

D、当数组名作为参数被传递给某个函数时,原数组中的元素的值可能被修改

12.若使用一维数组名作函数实参,则以下正确的说法是()。

A、必须在主调函数中说明此数组的大小

B、实参数组类型与形参数组类型可以不匹配

C、实参数组名与形参数组名必须一致

D、在被调用函数中,不需要考虑形参数组的类型

13.以下对二维数组a的正确说明是()。

A、float a(3,4);

B、int a[3][];

C、float a(3)(4);

D、double a[1][4];

14.以下正确的数组定义语句是()

A、int y[1][4]={1,2,3,4,5};

B、float x[3][]={{1},{2},{3}};

C、long s[2][3]={{1},{1,2,},{1,2,3}};

D、double t[][3]={0};

15.若有说明: int a[][4]={0,0};则下面不正确的叙述是()。

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

B、有元素a[0][0]和a[0][1]可得到初值0,其余元素均得不到初值0

C、二维数组a的第一维大小为1

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

因为二维数组a中初值的个数不能被第二维大小的值整除,则第一维的大小等于所得商数再加1,故数组a的行数为1

16.若二维数组a有m列,则在a[i][j]之前的元素个数为:()。

A) j*m+i B) i*m+j C) i*m+j-1 D) i*m+j+1

17.对两个数组a和b进行如下初始化:

char a[] = “ABCDEF”;

char b[] = {‘A’,‘B’,‘C’,‘D’,‘E’,‘F’};

则以下叙述正确的是()

A、a与b中都存放字符串

B、a数组比b数组长度长

C、a与b长度相同

D、a与b完全相同

18.设有数组定义: char array [ ]="China"; 则数组 array所占的空间为()。

A、5个字节

B、7个字节

C、4个字节

D、6个字节

19.下列数组说明中,正确的是()。

A、static char str[]; str="China";

B、static char str[]="China";

C、static char str1[5],str2[]={"China"}; str1=str2;

D、static char str1[],str2[];str2={"China"}; strcpy(str1,str2);

20.static char str[10]="China";数组元素个数为()。

A、5

B、10

C、6

D、9

21.若有定义语句:char c[5]={‘a’,’b’,’\0’,’c’,’\0’};,则执行语句pritnf(“%s”, c);的结

果是()

A、ab c

B、ab\0c

C、‘a’’b’

D、ab

22.若有 char s1[]="abc",s2[20];gets(s2); 则下列语句中能够实现当字符串s1大于字符串s2时,

输出s2的语句是()。

A、if(strcmp(s2,s1)>0) puts(s2);

B、if(strcmp(s1,s2)>0) puts(s2);

C、if(strcmp(s1,s2)==0) puts(s2);

D、if(strcmp(s1,s2)<0) puts(s2);

23.char a1[]="abc",a2[80]="1234";将a1串连接到a2串后面的语句是()。

A、strcat(a1,a2);

B、strcat(a2,a1);

C、strcpy(a2,a1);

D、strcpy(a1,a2);

24.char a[10];不能将字符串"abc"存储在数组中的是()。

A、strcpy(a,"abc");

B、int i;for(i=0;i<3;i++) a[i]=i+97; a[i]=0;

C、a="abc";

D、a[0]=0;strcat(a,"abc");

编程算法(函数实现):

●分段函数

●求和

●求阶乘(递归、非递归)

●最大值(最小值)、平均值

●斐波那契数列(递归、数组)

●判断素数、哥德巴赫猜想

●排序

●二分查找

字符串处理(长度、复制、连接、比较)、判断子串

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

相关主题
文本预览