C语言考试试题基础版

C语言考试试题基础版
C语言考试试题基础版

一、选择题

1. 在每个C 程序中都必须包含有这样一个函数,该函数的函数名为 。

A. main

B. MAIN

C. name

D. function

2. 在以下关于C 语言的注释的叙述中,不正确的是 。

A .注释可用"/*"、"*/"形式表示,也可用"//"形式表示

B .编译器在编译一个程序时,将跳过注释,不对其进行处理

C .编译器在编译一个程序时,可发现注释中的单词拼写错误

D .程序中注释的多少不会影响所生成的可执行文件的长度

3. 以下叙述不正确的是 。

A .在C 程序中,严格区分大小写字母

B .一个

C 源程序有且仅有一个main 函数

C .在C 程序中,注释只能位于一条语句的后面

D .一个C 程序总是从main 函数开始执行

4. 下列合法的标识符为

A. abde+

B. #KDJF

C. 67KDJ

D. DK3_

5. 关于字符串和字符的关系正确的是

A. “A ”与?A ?是相同的

B. 字符串是常量,字符是变量

C. “A ”与?A ?是不同的

D. “A ”与“A ”是相同的

6. 下面关于语句的说法正确的是

A. 下面这两段程序的执行效果是一致的

B. 空语句是只有一个分号的语句,它其实什么也不干

C. 语句的构成不一定需要分号

D. 语句的书写对程序的运行不起作用,因此可以随便写都可以

7. 以下各标识符中,合法的用户标识符组为 。

A. PAd ,P#d ,b-b ,abc ,_0123,ssiped

B. cin ,a10,CPP ,float ,del_word ,signed

C. void ,max ,hiy ,,list ,*jer

if (x>y)

{z=x; s=z*z;}

else

{z=y;s=1/(z*z);}

if (x>y) z=x; s=z*z; else z=y;s=1/(z*z);

D.a,temp,_isw,INT,keep,wind

8.字符串“\”E OF= -\61\””的长度是。

A.8B.9 C.12 D.非法字符串sin在C程序中对应的不正确的表达式为。9.数学式x

A.sqrt(sin(x)>0?sin(x):-sin(x)) B.sqrt(fabs(sinx))

C.sqrt(sqrt(sinx*sinx)) D.fabs(sqrt(sin(x)))

10.下列是C语言的有效标识符?

A._No1 B.No.1 C.12345 D.int

11.C语言中,表示一条语句结束的标号是

A.# B.; C.// D.}

12.每个C程序中都必须有且仅有一个

A.类B.预处理命令C.主函数D.语句13.下列数据类型不是C语言基本数据类型的是。

A.字符型B.整型C.实型D.数组

14.下列字符列中,可作为C语言程序自定义标识符是。

A.switch B.file C.break D.do

15.运算符+、<=、=、% 中,优先级最低的运算符是。

A.+ B.<= C.= D.%

16.下列字符列中,可以作为“字符串常量”的是。

A.ABC B.″xyz″C.′uvw′ D.′a′

17.字符串"vm\x43\\\np\102q"的长度是。

A.8 B.10 C.17 D.16

18.在C语言中,自定义的标识符。

A.能使用关键字并且不区分大小写

B.不能使用关键字并且不区分大小写

C.能使用关键字并且区分大小写

D.不能使用关键字并且区分大小写

19.设x和y均为逻辑型变量,则x && y为真的条件是。

A. 它们均为真

B. 其中一个为真

C. 它们均为假

D. 其中一个为假

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

A. 和(m= =0)等价

B. 和(m= =1)等价

C. 和(m!=0)等价

D. 和(m!=1)等价

21.在if语句中,用作判断的表达式为。

A. 关系表达式

B. 逻辑表达式

C. 算术表达式

D. 任意表达式

22.设i和k都是int类型,则以下for循环语句。

for ( i=0, k= -1; k=1; i++, k++ ) printf("****\n");

A. 判断循环结束的条件不合法

B. 是无限循环

C. 循环体一次也不执行

D. 循环体只执行一次

23.若有以下语句,则输出结果为。

int a=2,b=1;

string s1;

s1= a>b?"a大于b":"a小于b";

printf("%s\n", s1);

A. a大于b

B. a小于b

C. 1

D. 输出语句有错

24.int k=10;

while(k=0) k=k-1;

则下面描述正确的是。

A. while循环执行10次

B. 循环是无限循环

C. 循环体语句一次也不执行

D. 循环体语句执行一次

25.int a=1,b=2,c=2,t;

while(a

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

运行结果为。

A. 1,2,0

B. 2,1,0

C. 1,2,1

D. 2,1,1

26.int x=-1;

do

{x=x*x;}

while(!x);

下列说法正确的是。

A. 是死循环

B. 循环执行两次

C. 循环执行一次

D. 有语法错误

27.以下能正确计算1*2*3*…*10的程序段是。

A. do {i=1;s=1;

B. do {i=1;s=0;

s=s*i; i++;} s=s*i;i++;}

while(i<=10); while(i<=10);

C. i=1;s=1;

D. i=1;s=0;

do {s=s*i; do{s=s*i;

i++;} i++;}

while(i<=10); while(i<=10);

28.以下描述正确的是。

A. 由于do-while循环中循环体语句只是一条可执行语句,所以循环体内不能

使用复合语句

B. do-while循环由do开始,用while结束,在while(表达式)后面不能写分号

C. 在do-while循环体中,一定要有能使while后面表达式的值变为零(“假”)

的操作

D. do-while循环中,根据情况可以省略while

29.while和do-while循环的主要区别是。

A. do-while的循环体至少无条件执行一次

B. while的循环控制条件比do-while的循环控制条件严格

C. do-while允许从外部转到循环体内

D. do-while的循环体不能是复合语句

30.下面有关for循环的正确描述是。

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

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

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

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

31.对for(表达式1;;表达式3)可理解为。

A. for(表达式1;0;表达式3)

B. for(表达式1;1;表达式3)

C. for(表达式1;表达式1;表达式3)

D. or(表达式1;表达式3;表达式3)

32.在C编程语言中,以下正确的描述是。

A. continue语句的作用是结束整个循环的执行

B. 只能在循环体内和switch语句体内使用break语句

C. 在循坏体内使用break语句或continue语句的作用相同

D. 从多层循环嵌套中退出,只能使用goto语句

33.下面程序段。

for(t=1;t<=100;t++)

{scanf("%d",&x);

if(x<0) continue;

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

A. 当x<0时整个循环结束

B. x>=0时什么也不输出

C. cout永远也不执行

D. 最多允许输出100个非负整数

34.定义一个函数实现交换x和y的值,并将结果正确返回。能够实现此功能的是。

A. swap(int x, int y){ int t; t=x; x=y; y=t; }

B. swap(int *x, int *y){ int t; t=x; x=y; y=t; }

C. swap(int *x, int *y){ int t; t= *x; *x = *y; *y=t; }

D. swap(int *x, int *y){ int *t; t=x; x=y; y=t; }

35.若有代数式3ae/bc,则不正确的C语言表达式是。

A. a/b/c*e*3

B. 3*a*e/b/c

C. 3*a*e/b*c

D. a*e/c/b*3

36.以下表达式值为3的是。

A. 16-13%10

B. 2+3/2

C. 14/3-2

D. (2+6)/(12-9)

37.设有说明语句,int k=7, x=12;则以下能使值为3的表达式是。

A. x%=(k%=5)

B. x%=(k-k%5)

C. x%= k-k%5

D. (x%=k)-(k%=5)

38.若有条件表达式(exp)? A++: b--,则以下表达式中能完全等价于表达式(exp)的是。

A. (exp= =0)

B. (exp!=0)

C. (exp= =1)

D. (exp!=1)

39.设有以下语句:

typedef struct REC

{ char c; int a[4];} REC1;

则下面叙述中正确的是。

A.可以用REC定义结构体变量

B.REC1是struct REC类型的变量

C.REC是struct类型的变量

D.可以用REC1定义结构体变量

40.下列关于结构的语法错误的是

A.结构是由用户自定义的一种数据类型

B.结构中可设定若干个不同数据类型的成员

C.结构中成员的数据类型可以是另一个已定义的结构

D.在定义结构时,可以为成员设置默认值

41.以下关于结构体的叙述中,错误的是。

A.结构体是一种可由用户构造的数据类型

B.结构体中的成员可以具有不同的数据类型

C.结构体中的成员不可以与结构体变量同名

D.结构体中的成员可以是指向自身结构的指针类型

42.说明一个结构体变量时,系统分配给它的内存是。

A.各成员所需内存量的总和

B.结构中第一个成员所需内存量

C.成员中占内存量最大者所需的容量

D.结构中最后一个成员所需内存量

43.设有以下说明语句:

struct stu

{ int a; float b; } stutype;

则下面的叙述不正确的是。

A.struct是结构体类型的关键字

B.struct stu是用户定义的结构体类型名

C.stutype是用户定义的结构体类型名

D.a 和b都是结构体成员名

44.若有如下定义

struct data

{ int x,y;} test1={10,20}, test2;

则以下赋值语句中错误的是。

A. test2=test1;

B. test2.x=test1.x;

C. test2.x=test1.y

D. test2={30,40};

45.以下对结构体变量stu1中成员age的非法引用是。struct student

{ int age; int num;} stu1,*p;

p=&stu1;

A. stu1.age

B. student.age

C. p->age

D. (*p).age

46.当说明一个共用体变量时,系统分配给它的内存是。

A. 各成员所需内存量的总合

B.结构中第一个成员所需内存量

C.成员中占内存量最大者所需的容量

D.结构中最后一个成员所需内存量

47.以下对C语言中共用体类型数据的叙述正确的是。A.可以对共用体变量名直接赋值

B.一个共用体变量中可以同时存放其所有成员

C.一个共用体变量中不能同时存放其所有成员

D.共用体类型定义中不能出现结构体类型的成员

48.若有以下定义和语句:

union data

{ int i; char c; float f;} a;

int n;

则以下语句正确的是。

A.a=5; B. a={2,?a?,1.2}

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

D. n=1;

49.设有以下说明,则下面不正确的叙述是。

union

{ int i; char c; float f;} un;

A. un所占的内存长度等于成员f的长度

B.un的地址和它的成员地址都是同一地址

C.un可以作为函数参数

D.不能对un赋值,但可以在定义un时对它初始化

50.C语言共用体类型变量在程序运行期间

A.所有成员一直驻留在内存中

B.只有一个成员驻留在内存中

C.部分成员驻留在内存中

D.没有成员驻留在内存中

51.使用typedef定义一个新类型的正确步骤是。

A.(2)、(4)、(1)、(3) B. (1)、(3)、(2)、(4)

C.(2)、(1)、(4)、(3) D. (4)、(2)、(3)、(1)

(1)把变量名换成新类型名

(2)按定义变量的方法写出定义体

(3)用新类型名定义变量

(4)在最前面加上关键则typedef

52.下面对typedef的叙述中不正确的是。

A.用typedef可以定义各种类型名,但不能用来定义变量

B.用typedef可以增加新类型

C.用typedef只是将已存在的类型用一个新的标识符来代表

D.使用typedef有利于程序的通用和移植

53.下面试图为double说明一个新类型名real的语句中,正确定是。A.typedef real double;

B. typedef double real;

C. typedef real=double;

D. typedef double=real;

54.下面能正确进行字符串赋值操作的是。

A. char s[5]={“ABCDE”};

B. char s[5]={…A?, …B?, …C?, …D?, …E?};

C. char *s; s=“ABCDE”;

D. char *s; scanf(“%s”,s);

55.下面程序段的运行结果是。

char *s=”abcde”;

s+=2; printf(“%d”,s);

A. cde

B. 字符c

C. 字符c的地址

D. 无确定的输出结果

56.下面程序段的运行结果是。

char str[ ]=”ABC”, *p=str;

printf(“%d\n”, *(p+3));

A. 67

B. 0

C. 字符C的地址

D.字符C

57.下面程序段的运行结果是。

char a[ ]=”language”, *p;

p=a;

while(*p!=?u?){printf(“%c”,*p-32); p++;}

A. LANGUAGE

B. language

C. LANG

D. langUAGE

58.有如下说明语句,则以下不正确的叙述是。

char a[ ]=”It is mine”;

char *p=”It is mine”;

A. a+1表示的是字符t所在存储单元的地址

B.p指向另外的字符串时,字符串的长度不受限制

C.p变量中存放的地址值可以改变

D.a中只能存放10个字符

答案:

1.A 2.C 3.C 4.D 5.C 6.B 7.D 8.A

9.B 10.A 11.B 12.C 13.D 14.B 15.C 16.B 17.A 18.D 19.A 20.C 21.D 22.B 23.A

24.C 25.D 26.C 27.C 28.C 29.A 30.D 31.B 32.B 33.D 34.C

35.C 36.B 37. D 38. B 39. D 40. D 41. C 42. A

43. C 44. D 45. B 46.C 47.C 48.B 49.C 50.B 51.C

52. B 53. B 54.C 55.C 56. B 57. C 58. D

二、填空题

1.程序的三种基本的控制结构是:、、。

2.C语言中的每条基本语句以作为结束符,每条复合语句以作为结束符。

3.关系表达式x+y>5的相反表达式为。

4.下面的程序段中循环体的执行次数是。

a=10;b=0;

do{b+=2;a-=2+b;} while(a>=0);

5.下面程序段的运行结果为。

x=2;

do{printf("*"); x--; } while(!x==0);

6.已知int a[3][2]={3, 2, 1}; 则表达式“a[0][0]/a[0][1]”的值是。

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

8.如果一个函数无返回值,定义它时函数类型应是。

9.预处理命令以开头。

10.指针类型变量用于存储,在内存中它占有一个存储空间。

11.赋值语句在执行时先计算,再将该值转换成与一致的值,并将值赋给左部变量。

12.在程序中else总是与的if配对,而不管程序的书写格式如何。

13.在函数中使用语句返回值。

14.函数的形参在未被调用前分配空间,函数形参的要和实参相同。

15.函数调用一般分、,前者的特点是形参和实参各有独立的存储空间,形参的存储空间在函数被调用时才分配,形参内容的变化不影响实参,后者的特点是形参实参共用一个存储空间,形参内容的改变可以改变实参值。

16.在传值调用中,实际是把实参的传给形参。

17.int a[3]=3; 则a[2]= 。

18.int a[3]={1, 3, 5, 7}; 则。

19.数组由和构成,其数组元素的数据类型是。

20.声明长度为10的float型数组a,且初始化为0的语句是:。

21.指针是存放一个变量的的变量。

22.当数组名作形参时,相当于。

23.要访问数组元素可以采用、、。

24.定义一个指针p,它指向一个有6个整型元素的一维数组,定义语句为。

25.定义一个指针数组p,它有4个元素,每个指针指向一个整型数据,定义语句为。

26.指针可以指向字符串,在定义一个字符型指针时,可以给它初始化,目的是把字符串的放入指针变量。

27.指针可以指向函数,这时它所指的是函数的。

28.C语言的源程序必须通过和后,才能被计算机执行。

29.C语言源程序文件的后缀是;经过编译后,生成文件的后缀是;经过连接后,生成文件的后缀是。

30.在C语言中,表示逻辑“真”值用。

31.设y为int型变量,请写出描述“y是奇数”的表达式。

32.C语言提供的3种逻辑运算符是、和。

33.若x、y、z均为int型变量,则描述“x或y中有一个小于z”的表达式是。

34.设a、b、c均为int型变量且a=7.5, b=2,c=3.6,则表达式a>b && c>a || ab 的值是。

35.设a、b、c均为int型变量且a=6, b=4,c=2,则表达式!(a-b)+c-1 && b+c/2的值是。

36.设a、b均为int型变量且a=2, b=4,则表达式!(x=a) || (y=b) && 0的值是。

37.设a、b、c均为int型变量且a=1, b=4,c=3,则表达式!(a

38.若有条件“2

答案:

1.顺序结构选择结构循环结构

2.;}

3.x+y<=5

4. 3

5.**

6. 1

7.数组首地址

8.内置函数

9.#

10.所指变量的地址

11.表达式的值左部变量类型

12.它前面最近且未配对

13.return

14.不类型及数量

15.传值调用传址调用

16.值

17.0

18.会出错

19.数组名下标相同的

20.float a[10]={0};

21.地址

22.指针

23.下标法地址法指针法

24.int (*p)[6]

25.int *p[4]

26.首地址

27.入口地址

28.编译连接

29.c obj exe

30.非0数字

31.(y%2)= =1

32.&& || !

33.x

34.0

35.1

36.0

37.0

38.x<3 && x>2 || x<-10

三、填空完成下面的程序

1. 以下程序的功能是:输出x,y,z三个数中的最大者。请填空。

#include

int main( )

{ int x=4, y=6, z=7;

int u,v ;

if( x>y ) u=x;

else u=y;

if( u>z ) v=u;

else v=z;

printf(“v=%d”,v);

return 0;

}

2.以下程序的功能是:输入3个整数,按从大到小的顺序进行输出。请填空。#include

int main( )

{ int x,y,z,c;

scanf(“%d%d%d”,&x,&y,&z);

if( y

{ c=y;y=z;z=c;}

if( x

{ c=x;x=z;z=c;}

if( x

{ c=x;x=y;y=c;}

printf(“%d,%d,%d”,x,y,z);

return 0;

}

3.以下程序的功能是:输入一个字符,如果它是一个大写字母,则把它变成小写字母;如果它是一个小写字母,则把它变成大写字母;其他字符不变。请填空。#include

int main( )

{ char ch;

scanf(“%c”,&ch);

if( ch>=?A? && ch<=?Z?) ch=ch+32;

else if ( ch>=?a? && ch<=?z?) ch=ch-32;

printf(“%c”,ch);

return 0;

}

4.以下程序的功能是:根据输入的三角形的三条边,判断是否能组成三角形,若可以则输出它的面积和三角形的类型。请填空。

#include

#include

int main( )

{ float a,b,c;

float s,area;

scanf(“%f%f%f”,&a,&b,&c);

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

{ s=(a+b+c)/2;

area=sqrt(s*(s-a)*(s-b)*(s-c));

printf(“%f”,area);

if( a= =b && b= =c )

printf(“等边三角形”);

else if ( (a= =b && b!=c) || (a= =c && c!=b) || (c= =b && a!=c) ) printf(“等腰三角形”);

else if((a*a+b*b=c*c) || (a*a+c*c=b*b) || (b*b+c*c=a*a))

printf(“直角三角形”);

else printf(“一般三角形”);

}

else printf(“不能组成三角形”);

return 0;

}

5. 将以下含有switch语句的程序段改写成对应的含有非嵌套if语句的程序段。请填空。

含有switch语句的程序段:

int x,y,m;

y=(int)(x/10);

switch(y)

{ case 10: m=5;break;

case 9: m=4;break;

case 8: m=3;break;

case 7: m=2;break;

case 6: m=1;break;

default: m=0;

}

含有非嵌套if语句的程序段:

int x,m;

if( x<110 && x>=100 ) m=5;

if(x<100 && x>=90) m=4;

if(x<90 && x>=80) m=3;

if(x<80 && x>=70) m=2;

if(x<70 && x>=60) m=1;

if( x<60 || x>=110 ) m=0;

6. 根据以下给出的嵌套if语句,填写对应的switch语句,使它完成相同的功能。(假设mark的取值在1—100之间。)

if语句:

if(mar<60) k=1;

else if( mark<70) k=2;

else if( mark<80) k=3;

else if( mark<90) k=4;

else if( mark<=100) k=5;

switch语句:

switch((int)(mark/10) )

{case 0: case 1: case 2: case 3: case 4: case 5: k=1;break;

case 6: k=2; break;

case 7: k=3;break;

case 8: k=4;break;

case 9: case 10: k=5;

}

7. 下面程序的功能是从键盘输入若干学号,然后输出学号中百位数字是3的学号(输入0时结束循环),请填空。

#include

int main( )

{ long int num;

scanf(“%ld”,&num);

do

{ if (num/100%/10= =3) pringf(“%ld”,num);

scanf(“%ld”,&num);

} while (num!=0) ;

return 0;

}

8. 下面程序的功能是计算正整数2345的各位数字的平方和,请填空。

#include

int main( )

{ int n=2345,sum=0;

do

{ sum=sum+ (n%10)*(n%10) ;

n= n/10 ;

}while(n);

printf(“sum=%d”,sum);

return 0;

}

9. 下面程序的功能是求算式xyz+yzz=532中的x,y,z的值(其中xyz和yzz分别表示一个三位数),请填空。

#include

int main( )

{ int x,y,z,I,result=532;

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

for(y=1;y<10;y++)

for( z=0 ; z<10; z++)

{ i=100*x+10*y+z+100*y+10*z+z;

if (i= =result)

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

}

return 0;

}

10.有1020个西瓜,第一天卖一半多两个,以后每天卖剩下的一半多两个,下面的程序统计买完所需的天数,请填空。

#include

int main( )

{ int day=0, x1=1020, x2;

while (x1)

{ x2= x1/2-2 ;

x1=x2;

day++;

}

printf(“day=%d\n”,day);

return 0;

}

11.下面的程序的功能是用do-while语句求1—1000之间满足“用3除余2,用5除余3,用7除余2”的数,且一行只打印5个数,请填空。

#include

int main( )

{ int i=1,j=0;

do

{ if (i%3= =2 && i%5= =3 && I%7= =2)

{ printf(“%4d”,i);

j++;

if (j%5= =0) printf(“\n”);

}

i=i+1;

} while(i<1000);

return 0;

}

12.下面程序的功能是求1000以内的所有完全数。请填空。(说明:一个数如果

恰好等于它的因子之和(除自身外),则称该数为完全数。例如:6=1+2+3,6为完全数)

#include

int main( )

{ int a,k,m;

for(a=1;a<=1000;++)

{ for( m=0, k=1 ; k<=a/2;k++) if(!(a%k)) m=m+k;

if(m= =a) printf(“%4d”,a);

}

return 0;

}

13.下面的程序是从键盘输入的10个整数中,找出一个能被7正处的数,若找到,打印次数;若未找到,打印not exist。请填空。

#include

int main( )

{ int k,a;

for(k=1;k<=10;k++)

{ scanf(“%d”,&a);

if(a%7= =0) break;

}

if (k<=10) printf(“%d\n”,a);

else printf(“not exist\n”);

return 0;

}

四、给出下列程序运行后的输出结果

1. 当a=1,b=3,c=5,d=4时,执行以下程序段后x的值是 2 。

if (a

if(c

else

if(a

if(b

else x=3;

else x=6;

else x=7;

2. 以下程序的输出是-1 。#include

int main( )

{ int a=100,x=10,y=20,ok1=5,ok2=0;

if(x

if(y!=10)

if(!ok1)

a=1;

else

if(ok2) a=10;

a=-1;

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

return 0;

}

3. 以下程序的输出是 2 。

#include

int main( )

{ int x=2,y=-1,z=2;

if(x

if(y<0) z=0;

else z+=1;

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

return 0;

}

4. 以下程序的输出是OK 。#include

int main( )

{ int x=1;

if(x=2)

printf(“OK”);

else if(x<2) pirntf(“%d\n”,x);

else printf(“Quit”);

return 0;

}

5. 若运行时为变量x输入12,则以下程序的运行结果是0 。

#include

int main( )

{ int x, y;

scanf(“%d”,&x);

y=x>12? X+10: x-12;

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

return 0;

}

6. 若运行时输入:2<回车>,则以下程序的运行结果是2nd class postage is 14p 。

#include

int main( )

{ char class;

printf(“Enter 1 for 1st class post or 2 for 2nd post”);

scanf(“%c”,&class);

if(calss= =?1?)

printf(“1st class postage is 19p”);

else

printf(“2nd class postage is 14p”);

return 0;

}

7. 若运行时输入 4.4<回车>,则以下程序的运行结果是Selling Price(0.3)$ 5.72 。

#include

int main( )

{ float costPrice, sellingPrice;

printf(“Enter costPrice $:”);

scanf(“%f”,&costPrice);

if( costPrice>=5 )

{sellingPrice=costPrice+costPrice*0.25;

printf(“Selling Price(0.25)$ %6.2f”,sellingPrice);

}

else

{ sellingPrice=costPrice+costPrice*0.3;

printf(“Selling Price(0.3)$ %6.2f”,sellingPrice);

}

return 0;

}

8. 若运行时输入:1605<回车>,则以下程序的运行结果是4:05PM 。#include

int main( )

{ int t,h,m;

scanf(“%d”,&t);

h=(t/100)%12;

if(h= =0) h=12;

printf(“%d:”,h);

m=t%100;

if(m<10) printf(“0”);

printf(“%d”,m);

if(t<1200 || t= =2400) printf(“AM”);

else printf(“PM”);

return 0;

}

9. 以下程序的运行结果是20 。

#include

int main( )

{ int a,b,c,d,x;

a=0;

c=0;

b=1;

d=20;

if(a) d=d-10;

else if(!b)

if(!c) x=15;

else x=25;

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

return 0;

}

10. 以下程序的输出结果是。

#include

int main( )

{ int x,y;

x=5;

switch(x)

{ case 1:

case 2:

case 3:

case 4: printf(“x<5\n”);

case 5: printf(“x=5\n”);

default: printf(“The value of x is unknwn.\n”);

return 0;

}

输出结果:

x=5

The value of x is unknwn.

11. 下面程序的运行结果是123 。

#include

int main( )

{ int num=0;

while(num<=2)

{ num++;

printf(“%d”,num);

}

return 0;

}

12.若运行以下程序时,从键盘输入3.6 2.4<回车>,则下面程序的运行结果是1.600000 。

#include

#include

int main( )

{ float x,y,z;

scanf(“%f%f”,&x,&y);

z=x/y;

while(1)

if(fabs(z)>1.0 {x=y; y=z; z=x/y;}

else break;

printf(“%f\n”,y);

return 0;

}

13. 下面程序的运行结果是8 。

嵌入式C语言经典笔试题目

嵌入式c语言经典笔试题目 1 .用预处理指令#define声明一个常数,用以表明1年中有多少秒(忽略闰年问题) #define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL 我在这想看到几件事情: 1) #define语法的基本知识(例如:不能以分号结束,括号的使用,等等) 2)懂得预处理器将为你计算常数表达式的值,因此,直接写出你是如何计算一年中有多少秒而不是计算出实际的值,是更清晰而没有代价的。 3)意识到这个表达式将使一个16位机的整型数溢出-因此要用到长整型符号L,告诉编译器这个常数是的长整型数。 4)如果你在你的表达式中用到UL(表示无符号长整型),那么你有了一个好的起点。记住,第一印象很重要。 2 .写一个"标准"宏MIN,这个宏输入两个参数并返回较小的一个。 #define MIN(A,B)((A)<= (B) ? (A) : (B)) 这个测试是为下面的目的而设的: 1)标识#define在宏中应用的基本知识。这是很重要的。因为在嵌入(inline)操作符变为标准C的一部分之前,宏是方便产生嵌入代码的唯一方法,对于嵌入式系统来说,为了能达到要求的性能,嵌入代码经常是必须的方法。 2)三重条件操作符的知识。这个操作符存在C语言中的原因是它使得编译器能产生比if-then-else更优化的代码,了解这个用法是很重要的。 3)懂得在宏中小心地把参数用括号括起来 4)我也用这个问题开始讨论宏的副作用,例如:当你写下面的代码时会发生什么事? least = MIN(*p++, b); 3.预处理器标识#error的目的是什么? 如果你不知道答案,请看参考文献1。这问题对区分一个正常的伙计和一个书呆子是很有用的。只有书呆子才会读C语言课本的附录去找出象这种问题的答案。当然如果你不是在找一个书呆子,那么应试者最好希望自己不要知道答案。 死循环(Infinite loops) 4.嵌入式系统中经常要用到无限循环,你怎么样用C编写死循环呢? 这个问题用几个解决方案。我首选的方案是: while(1) { } 一些程序员更喜欢如下方案: for(;;) { } 这个实现方式让我为难,因为这个语法没有确切表达到底怎么回事。如果一个应试者给出这个作为方案,

大学C语言考试试题及答案

精选考试类文档,如果您需要使用本文档,请点击下载! 祝同学们考得一个好成绩,心想事成,万事如意! 大学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语言笔试题(答案)(精心整理)

笔试题 一、填空题(每个空4分,共28分) 1)struct tagABC { char name[10]; char sex; long sno; float score[4]; }*pAbc;(四字节对齐) pAbc=NULL; 那么,执行pAbc+=2;之后pAbc的值为(64 ) 2)如下代码,最终value的值是(8) int *p1,*p2; int value; p1=(int*)0×400; p2=(int*)0×408; value = p2-p1; 3)如下代码,printf的结果为(2) #include〈stdio.h〉 #include〈string.h〉 void main(void) { char acNew[20]= “\\0\0”; printf(“%d\n”,strlen(acNew)); } 4) 有如下程序段,运行该程序的输出结果是(33) main () { int y=3,x=3,z=1; printf(“%d%d\n”,(++x,y++),z+2); } 5)设有:int a=1,b=2,c=3,d=4,m=2,n=2;执行(m=a>b)&&(n=c>d)后,n的值为(2)6)struct tagAAA { Unsigned char ucId:1; Unsigned char ucPara0:2; Unsigned char ucState:6; Unsigned char ucTail:4; Unsigned char ucAvail; Unsigned char unTail2:4; Unsigned long ulData; }AAA_S 问:AAA_S在字节对齐分别为1,4情况下,占用的空间大小分别是多少?( 9)(12 )

C语言考试试题

试题 课程名称C语言程序设计适用时间 试卷类别 A 适用专业、年级、班 一、选择题(每小题2分, 2×25=50分) 1.下列叙述错误的是( )。 A) C程序中的每条语句都用一个分号作为结束符B) C程序中的每条命令都用一个分号作为结束符 C) C程序中的变量必须先定义,后使用 D) C语言以小写字母作为基本书写形式,并且C语言要区分字母的大小写 2.以下叙述不正确的是( )。 A) 一个C源程序必须包含一个main函数B) 一个C源程序可由一个或多个函数组成 C) C程序的基本组成单位是函数D) 在C程序中,注释说明只能位于一条语句的后面 3.C语言中最简单的数据类型包括( )。 A)整型、实型、逻辑型B)整型、实型、字符型 C)整型、字符型、逻辑型D)字符型、实型、逻辑型 4.C语言中运算对象必须是整型的运算符是( )。 A)%= B)/ C)= D)<= 5.若变量a,i已正确定义,且i已正确赋值,合法的语句是( )。 A)a= =1 B)++i;C)a=a++=5;D)a=int(i); 6.下列运算符中优先级最高的是( )。 A) < B) + C) && D) ! = 7.设有说明:char w;int x;float y;double z;则表达式w*x+z-y 值的数据类型是( )。 A) int B) float C) double D) char 8.设x和y均为int型变量,则语句:x+=y;y=x-y;x-=y;的功能是( )。 A)把x和y按从大到小排列B)把x和y按从小到大排列C)无确定结果D)交换x和y中的值 9.设整型变量a,b的值均为8, printf("%d,%d",(a++,++b),b--);的输出是( )。 A)8,8 B)8,7 C)9,9 D)8,9 10.若有语句scanf("%d%d",&a,&b);要使变量a,b分别得到10和20,正确的输入形式为( )。 A)10 20 B)10,20 C)1020 D)10:20 11.判断char型变量ch是否为大写字母的正确表达式是( )。 A)'A'<=CH<='Z' B) (CH>='A')& (CH<='Z') C)(CH>='A')&& (CH<='Z') D) ('A'<=ch)AND('Z'>=ch) 12.有如下程序 main( ) { int x=1,a=0,b=0; switch(x) { case 0: b++; case 1: a++; case 2: a++;b++; } printf("a=%d,b=%d\n",a,b);} 该程序的输出结果是( )。 A) a=2,b=1 B) a=1,b=1 C) a=1,b=0 D) a=2,b=2 13.以下程序的功能是:按顺序读入10名学生4门课程的成绩,计算出每位学生的平均分并输出,程序如下: main( ) { int n,k; float score,sum,ave; sum=0.0; for(n=1;n<=10;n++) { for(k=1;k<=4;k++) { scanf("%f",&score); sum+=score; } ave=sum/4.0; printf("NO%d:%f\n",n,ave); } } 上述程序运行后结果不正确,调试中发现有一条语句出现在程序中的位置不正确。这条语句是( )。 A) sum=0.0; B) sum+=score; C) ave=sun/4.0; D) printf("NO%d:%f\n",n,ave);

c语言笔试题目及答案

c语言笔试题目及答案 C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。下面是c语言笔试题目及答案,请参考。 c语言笔试题目及答案 一、选择题((1)~(10)每小题2分,(11)~(50)每小题1分,共60分) 下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的,请将正确的选 项涂写在答题卡相应位置上,答在试卷上不得分。 (1)数据的存储结构是指________。 A)存储在外存中的数据 B)数据所占的存储空间量 C)数据在计算机中的顺序存储方式 D)数据的逻辑结构在计算机中的表示 答案:D 评析:数据的逻辑结构在计算机存储空间中的存放形式形式称为数据的存储结构(也称数据的物理结构)。 (2)下列关于栈的描述中错误的是________。 A)栈是先进后出的线性表

B)栈只能顺序存储 C)栈具有记忆作用 D)对栈的插入与删除操作中,不需要改变栈底指针 答案:B 评析:栈是一种特殊的线性表,又称先进后出表(FILO—First In Last Out)。 (3)对于长度为n的线性表,在最坏情况下,下列各排序法所对应的比较次数中正确的是 ________。 A)冒泡排序为n2 B)冒泡排序为n C)快速排序为n D)快速排序为n(n一1)/2 答案:D 评析:假设线性表的长度为n,则在最坏情况下,冒泡排序需要经过n/2遍的从前往后扫描和n/2遍的从后往前扫描,需要比较次数为n(n-1)/2。快速排序法的最坏情况比较次数也是n(n-1)/2。 (4)对长度为n的线性表进行顺序查找,在最坏情况下所需要的比较次数为________。 A)log2n B)n/2 C)n D)n+l 答案:C 评析:顺序查找过程中,如果被查找的元素是线性表中的最后一个元素,或者元素不在线性表中,则需要与线性表中所有的元素进行比较。对长度为n的线性表进行顺序查找,在最坏情况下需要比较

C语言考试试卷及答案

2011-2012学年第一学期 C语言程序设计A 课程A卷考试题 共 4 页此第 1 页成绩 一、单项选择题(每小题2分,共40分) 1. C语言中合法的字符常量是() A.n B.’\n’ C.110 D.”n” 2. 有以下程序: main( ) { char ch=’A’; printf(“ch(1)=%d,ch(2)=%c\n”,ch,ch+1); } 程序运行后的输出结果是() A. ch(1)=65,ch(2)=A B. ch(1)=97,ch(2)=A C. ch(1)=65,ch(2)=B D. ch(1)=97,ch(2)=B 3. 能表示a不能被2整除且a、b不相等,但a、b的和等于0的C语言逻辑表达式是() A. a==-b&&a%2==0 B. a!=b&&a+b==0&&a%2 C. !(a%2)&&a==-b D.a%2==0&&a+b==0 4. 以下程序段中语句” printf("i=%d,j=%d\n",i,j);”的执行次数是() int i, j; for(i=3;i ;i--) for(j=1;j<5;j++) printf("i=%d,j=%d\n",i,j); A. 12 B. 20 C. 15 D. 24 5. 执行以下程序段后,x[2]的值是() int x[10]={1,2,3,4,5,6,7,8,9,10},i,j,t; i=0;j=9; while(i

嵌入式C语言面试题汇总(超经典)

第一部分:基本概念及其它问答题 1、关键字static的作用是什么? 这个简单的问题很少有人能回答完全。在C语言中,关键字static有三个明显的作用: 1). 在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 2). 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。 3). 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用。 大多数应试者能正确回答第一部分,一部分能正确回答第二部分,同是很少的人能懂得第三部分。这是一个应试者的严重的缺点,因为他显然不懂得本地化数据和代码范围的好处和重要性。 2、“引用”与指针的区别是什么? 答、1) 引用必须被初始化,指针不必。 2) 引用初始化以后不能被改变,指针可以改变所指的对象。 3) 不存在指向空值的引用,但是存在指向空值的指针。 指针通过某个指针变量指向一个对象后,对它所指向的变量间接操作。程序中使用指针,程序的可读性差;而引用本身就是目标变量的别名,对引用的操作就是对目标变量的操作。 流操作符<<和>>、赋值操作符=的返回值、拷贝构造函数的参数、赋值操作符=的参数、其它情况都推荐使用引用。 3、.h头文件中的ifndef/define/endif 的作用? 答:防止该头文件被重复引用。 4、#include 与#include “file.h”的区别? 答:前者是从Standard Library的路径寻找和引用file.h,而后者是从当前工作路径搜寻并引用file.h。 5、描述实时系统的基本特性 答:在特定时间内完成特定的任务,实时性与可靠性。 6、全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 答:全局变量储存在静态数据区,局部变量在堆栈中。 7、什么是平衡二叉树? 答:左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于1。 8、堆栈溢出一般是由什么原因导致的? 答:1.没有回收垃圾资源 2.层次太深的递归调用

c语言期中考试试题及答案

中国民航大学2009-2010学年第二学期 《C 语言程序设计》期中考试试卷 课程编号:03402513 试卷类型: A 卷 考试形式:笔试 考试日期: 注意事项:1.请将试卷最后一页的答题纸撕下,将答案填写在其中;2.交卷时请确认答题纸是否按要求写好姓名等信息并与试题一起上交;3.不准携带任何书籍、资料、纸张等。4.草稿纸用试卷的背面。 一、单项选择题(1空1分,共20分) 1、C 语言程序的基本结构是(【1】) 。 【1】 A) 函数 B) 语句 C) 字符 D) 程序行 2、一个C 程序的执行是(【2】) 。 【2】 A) 从本程序的主函数开始,到本程序的主函数结束

B)从本程序的第一个函数开始,到本程序的最后一个函数结束 C) 从本程序的主函数开始,到本程序的最后一个函数结束 D)从本程序的第一个函数开始,到本程序的主函数结束3、下列四个叙述中,错误的是(【3】) 。 【3】 A) 一个C源程序必须有且只能有一个主函数 B) 一个C源程序可以含一个或多个子函数 C) 在C源程序中注释说明必须位于语句之后 D) C源程序的基本结构是函数 4、下面不属于C语言保留字的是(【4】) 。 【4】 A) short B) ELSE C) extern D) for 5、下列四个叙述中,正确的是(【5】) 。 【5】 A) 库函数也是C语言本身的组成部分 B) C语言中的输入输出操作是由相应语句完成的

C) 库函数是C编译系统提供的功能函数 D) 标题文件(头文件)可以在程序的函数内部调用 6、下列四组数据类型中,C语言允许的一组是(【6】)。 【6】 A) 整型、实型、逻辑型 B) 整型、实型、字符型 C) 整型、双精度型、布尔型 D) 整型、实型、复型 7、在C语言中不同数据类型的的长度是(【7】)。 【7】 A) 固定的 B) 由用户自己定义的 C) 任意的 D) 与机器字长有关 8、下列四组(八进制或十六进制)常数中,正确的一组是(【8】)。【8】 A) 016 0xbf 18 B) 0abc 017 0xa C) 010 -0x11 0x16 D) 0A12 7FF -123 9、下列四组转义字符中,合法的一组是(【9】)。 【9】 A)‘\t’‘\\’‘\n’ B)‘\’‘\017’‘\x’

C语言考试试题

1.若x为int型变量,则执行以下语句后,x的值为-60。 x=6; x+=x-=x*x; x=x-x*x=-30 x=x+x=-60 2.若有定义int a[2][3]; 则对a数组的第i行第j列元素地址的正确引用为a[i]+j。 3.若有说明:int i, j=2,*p=&i;,则能完成i=j赋值功能的语句是*p=*&j。 4.以下叙述正确的是define和if都不能定义为用户标识符。 5. 以下程序的输出结果是2。 #define SQR(X) X*X main() { int a=16, k=2, m=1; a/=SQR(k+m)/SQR(k+m); a/=k+k*m+m/k+k*m+m printf("%d\n",a); } 6. 以下程序的输出结果是4。 main() {int b[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1; for(i=0;i<3;i++) for(j=i;j<=i;j++) for(j=i;j<=i;j++) t=t+b[i][j]; { t=t+b[i][j];} printf("%d\n",t); printf("%d\n",t); }_ 7. 编一个程序,打入星期号,输出该星期的英文名字。例如,输入"1"则输出"Monday",说明:星期日编号为0,要求用指针数组处理。 main() { char *name[7]={"Sunday","Monday","Tuesday","Wednesday","Thursday","Friday", "Saturday"}; int n; printf("\nInput the number(0-6):"); scanf("%d", &n); if ((n< 7) && (n>=0)) printf("\nThe name is: %s",name[n]); else printf("\nInput error"); } 8. 局部变量是静态存储变量。错误 9. "文件包含"处理是指一个源文件可以将另一个源文件的内容全部包含进来。正确 10. 若有定义:int *p1,*p2;则p1+p2无实际意义。正确 11. 若在函数内定义形参数组a:int a[3][4];则数组a中各元素可在程序的编译阶段得到初值0。错误 12. 以下不能正确定义二维数组的选项是int a[2][]={{1,2},{3,4}};。 13. 以下程序的输出结果是6 15 15。 int d=1; fun(int p) { static int d=5; d+=p; printf("%d ",d); return(d); } main( ) { int a=3; printf("%d \n", fun(a+fun(d))); }

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. main B. MAIN C. name D. function 2. 在以下关于C 语言的注释的叙述中,不正确的是 。 A .注释可用"/*"、"*/"形式表示,也可用"//"形式表示 B .编译器在编译一个程序时,将跳过注释,不对其进行处理 C .编译器在编译一个程序时,可发现注释中的单词拼写错误 D .程序中注释的多少不会影响所生成的可执行文件的长度 3. 以下叙述不正确的是 。 A .在C 程序中,严格区分大小写字母 B .一个 C 源程序有且仅有一个main 函数 C .在C 程序中,注释只能位于一条语句的后面 D .一个C 程序总是从main 函数开始执行 4. 下列合法的标识符为 A. abde+ B. #KDJF C. 67KDJ D. DK3_ 5. 关于字符串和字符的关系正确的是 A. “A ”与?A ?是相同的 B. 字符串是常量,字符是变量 C. “A ”与?A ?是不同的 D. “A ”与“A ”是相同的 6. 下面关于语句的说法正确的是 A. 下面这两段程序的执行效果是一致的 B. 空语句是只有一个分号的语句,它其实什么也不干 C. 语句的构成不一定需要分号 D. 语句的书写对程序的运行不起作用,因此可以随便写都可以 7. 以下各标识符中,合法的用户标识符组为 。 A. PAd ,P#d ,b-b ,abc ,_0123,ssiped B. cin ,a10,CPP ,float ,del_word ,signed C. void ,max ,hiy ,,list ,*jer if (x>y) {z=x; s=z*z;} else {z=y;s=1/(z*z);} if (x>y) z=x; s=z*z; else z=y;s=1/(z*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

C语言考试题及答案

一、单项选择题:(10分,每题2分) 1.char *p[10];该语句声明了一个: c 。 A)指向含有10个元素的一维字符型数组的指针变量p B)指向长度不超过10的字符串的指针变量p C)有10个元素的指针数组p,每个元素可以指向一个字符串 D) 有10个元素的指针数组p,每个元素存放一个字符串 2.若int x;且有下面的程序片断,则输出结果为: D 。 for (x=3; x<6; x++) { printf((x%2) ? "##%d" : "**%d\n", x); } A) ##3B) **3C) **3D)##3**4 **4 ##4 ##4**5 ##5 ##5 **5 3.在while(!x)语句中的!x与下面条件表达式等价的是:D 。 A) x!=0 B) x==1 C) x!=1 D) x==0 4.已知 struct point { int x; int y; }; struct rect { struct point pt1; struct point pt2; }; struct rect rt; struct rect *rp = &rt; 则下面哪一种引用是不正确的__D______。 A) r t.pt1.x B) (*rp).pt1.x C) r p->pt1.x D) rt->pt1.x 5.若二维数组a有m行n列,则下面能够正确引用元素a[i][j]的为: C 。 A) *(a+j*n+i) B) *(a+i*n+j) C) *(*(a+i)+j) D) *(*a+i)+j CDDDC 二、分析程序并写出运行结果。(25分,每题5分) 1. #include main()

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语言笔试题大全

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语言考试试题

六 ━━━━━━━━━━━━━━━ 一、判断共10题(共计20分) ━━━━━━━━━━━━━━━ 第1题(2.0分)题号:1259 若定义int m[]={1,2,3,4,5};则m[1]的值为2. 答案:Y 第2题(2.0分)题号:1275 如果定义一个函数时省略类型,则函数没有返回值. 答案:N 第3题(2.0分)题号:12 结构体类型只有一种。 答案:N 第4题(2.0分)题号:1241 在C语言的标识符中,大写字母和小写字母完全等价. 答案: 第5题(2.0分)题号:1271 定义一种结构体类型后,则用该类型定义的所有变量占用内存的大小是相同的. 答案:Y 第6题(2.0分)题号:1269 若定义int a[4]={1,2,3,4};若超界引用a[4]则编译时不报错. 答案:Y 第7题(2.0分)题号:1096 C语言中"%"运算符的运算对象必须是整型. 答案:Y 第8题(2.0分)题号:1109 两个字符串中的字符个数相同时才能进行字符 串大小的比较 答案:N 第9题(2.0分)题号:1135 语句printf("%c",65);存在语法错误. 答案:N 第10题(2.0分)题号:32 若有说明int c;则while(c=getchar());是正 确的C语句。 答案:Y ━━━━━━━━━━━━━━━━━ 二、单项选择共15题(共计30分) ━━━━━━━━━━━━━━━━━ 第1题(2.0分)题号:3114 C语言源程序名的后缀是 A:exe B:c C:obj D:cp 答案:B 第2题(2.0分)题号:184 以下不能正确定义二维数组的选项是 ( ). A:int a[2][2]={{1},{2}}; B:int a[][2]={1,2,3,4}; C:int a[2][2]={{1},2,3}; D:int a[2][]={{1,2},{3,4}}; 答案:D 第3题(2.0分)题号:129 以下各标识符中,合法的用户标识符为 ( ). A:A#C B:mystery C:main D:ab* 答案:B 第4题(2.0分)题号:632 以下叙述正确的是()。 A:do-while语句构成的循环不能用其它语句构 成的循环来代替. B:do-while语句构成的循环只能用break语句 退出. C:用do-while语句构成的循环,在while后的表 达式为非零时结束循环. D:用do-while语句构成的循环,在while后的表 达式为零时结束循环 答案:D 第5题(2.0分)题号:149 以下程序的输出结果是()。 main() {float x=3.6; int i; i=(int)x; printf("x=%f,i=%d\n",x,i); } A:x=3.600000,i=4 B:x=3,i=3 C:x=3.600000,i=3 D:x=3 i=3.600000 答案:C 第6题(2.0分)题号:172 在C语言程序中()。 A:函数的定义可以嵌套,但函数的调用不可以 嵌套 B:函数的定义不可以嵌套,但函数的调用可以 嵌套 C:函数的定义和函数调用均可以嵌套 D:函数的定义和函数调用不可以嵌套 答案:B 第7题(2.0分)题号:678 当调用函数时,实参是一个数组名,则向函数 传送的是()。 A:数组的长度 B:数组的首地址 C:数组每一个元素的地址 D:数组每个元素中的值 答案:B 第8题(2.0分)题号:125 下列程序的输出结果是()。 main() {int a=7,b=5; printf("%d\n",b=b/a); } A:0 B:5 C:1

嵌入式开发c语言经典笔试题-含答案

void e(int ); main(){ int a; a=3; e(a);}void e(int n){ if(n>0) { e(--n); printf("%d" , n); e(--n); }}这段程序的输出是: A.0 1 2 0 B.0 1 2 1 C.1 2 0 1 D.0 2 1 1 typedef int (*test) ( float * , float*)test tmp; tmp 的类型是【】 A.函数的指针,该函数以两个指向浮点数(float)的指针(pointer)作为参数(arguments) Pointer to function of having two arguments that is pointer to float B.整型 C.函数的指针,该函数以两个指向浮点数(float)的指针(pointer)作为参数(arguments),并且函数的返回值类型是整型Pointer to function having two argument that is pointer to float and return int D.以上都不是 第3 题 main(){ char p; char buf[10] ={ 1,2,3,4,5,6,9,8}; p = (buf+1)[5]; printf("%d" , p);}这段程序的输出是:【】 A.5 B.6 C.9 D.以上都不对 第4 题 Void f(char**);main(){ char * argv[] = { "ab" ,"cd" , "ef" ,"gh", "ij" ,"kl" }; f( argv );}void f( char **p ){ char* t; t= (p+= sizeof(int))[-1]; printf( "%s" , t);}这段程序的输出是:【】 A.ab B.cd C.ef D.gh 第5 题 #includeint ripple ( int , ...);main(){ int num; num = ripple ( 3, 5,7); printf( " %d" , num);}int ripple (int n, ...){ int i , j; int k; va_list p; k= 0; j = 1; va_start( p , n); for (; j

C语言试题

一、Select one answer from the four answers:( for each question, a total of 30 points) 1.Which of the following expressiong is the equivalent to k=n++? ( ). A) k=n,n=n+1 B)n=n+1,k=n C)k=++n D)k+=n+1 2.What will be the printed output of the following program? ( ). main( ) { int x=10,y=10; printf("%d %d\n",x--,--y); } A)10 10 B) 9 9 C) 9 10 D) 10 9 3.Choose the correct output that following program produces. ( ). main() { int x; x=-3+4*5-6; printf("%d",x); x= 3+4%5-6; printf("%d",x); x=-3*4%6/5; printf("%d",x); x=(7+6)%5/2; printf("%d",x); } A) 11 1 0 1 B) 11 -3 2 1 C) 12 -3 2 1 D)11 1 2 1 4. The printed output of the following program is ( ). #include main() { int y=10; do{y--;}while(--y); printf("%d\n",y--); } A) -1 B) 1 C) 8 D) 0