2019年电大C语言考试题库(c语言小题+编程)

2019年电大C语言考试题库(c语言小题+编程)
2019年电大C语言考试题库(c语言小题+编程)

C语言程序设计课程期末复习练习

一、单选题

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

A. main

B. MAIN

C. name

D. function

2.每个C语言程序文件的编译错误分为()类。

A. 1

B. 2

C. 3

D. 4

3. 字符串"a+b=12\n"的长度为()。

A. 6

B. 7

C. 8

D. 9

4. 在switch语句的每个case块中,假定都是以break语句结束的,则此switch语句容易被改写为()语句。

A. for

B. if

C. do

D. while

5. 在下面的do-while循环语句中,其循环体语句被执行的次数为()。

int i=0; do i++; while(i<10);

A. 4

B. 3

C. 5

D. 10

6. 将两个字符串连接起来组成一个字符串时,选用的函数为()。

A. strlen()

B. strcap()

C. strcat()

D. strcmp()

7. 若用数组名作为函数调用的实参,传递给形参的是()。

A. 数组的首地址

B. 数组中第一个元素的值

C. 数组中全部元素的值

D. 数组元素的个数

8. 假定a为一个整数类型的数组名,整数类型的长度为4,则元素a[4]的地址比a数组的首地址大( )个字节。

A. 4

B. 8

C. 16

D. 32

9. 假定s被定义为指针类型char *的变量,初始指向的字符串为"Hello world!",若要使变量p指向s所指向的字符串,则p应定义为()。

A. char *p=s;

B. char *p=&s;

C. char *p;p=*s;

D. char *p; p=&s;

10. 从一个数据文件中读入以换行符结束的一行字符串的函数为()。

A. gets()

B. fgets()

C. getc()

D. fgetc()

11. 由C语言目标文件连接而成的可执行文件的缺省扩展名为( )。

A. cpp

B. exe

C. obj

D. c

12. 设有两条语句为“int a=12; a+=a*a;”,则执行结束后,a的值为( )。

A. 12

B. 144

C. 156

D. 288

13. 带有随机函数调用的表达式rand()%20的值在( )区间内。

A. 1~19

B. 1~20

C. 0~19

D. 0~20

14. for循环语句“for(i=0; i

A. (n+1)/2

B. n/2+1

C. n/2-1

D. n-1

15. 在下列的字符数组定义中,存在语法错误的是()。

A. char a[20]="abcdefg";

B. char a[]="x+y=55.";

C. char a[15]={'1','2'};

D. char a[10]='5';

16. 若有一个函数原型为“double *function()”,则它的返回值类型为()。

A. 实数型

B. 实数指针型

C. 函数指针型

D. 数组型

17. 在C语言中,所有预处理命令都是以( )符号开头的。

A. *

B. #

C. &

D. @

18. 假定整数指针p所指数据单元的值为30,p+1所指数据单元的值为40,则执行*p++后,p所指数据单元的值为()。

A. 40

B. 30

C. 70

D. 10

19. 若要使p指向二维整型数组a[10][20],则p的类型为()。

A. int *

B. int **

C. int *[20]

D. int(*)[20]

20. 表示文件结束符的符号常量为()

A. eof

B. Eof

C. EOF

D. feof

21. 程序运行中需要从键盘上输入多于一个数据时,各数据之间默认使用( )符号作为分隔符。

A. 空格或逗号

B. 逗号或回车

C. 逗号或分号

D. 空格或回车

22. 逻辑表达式(x>0 && x<=10)的相反表达式为()。

A. x<=0 || x>10

B. x<=0 && x>10

C. x<=0 || x<=10

D. x>0 && x>10

23. 当处理特定问题时的循环次数已知时,通常采用()循环来解决。

A. for

B. while

C. do-while

D. switch

24. 假定i的初值为0,则在循环语句“while(i

A. n-1

B. n

C. n+1

D. n/2

25. 假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为()。

A. 2

B. 4

C. 6

D. 8

26. 在下列选项中,不正确的函数原型格式为()。

A. int Function(int a);

B.void Function (char);

C. int Function(a);

D.void int(double* a);

27. 假定p是一个指向float型数据的指针,则p+1所指数据的地址比p所指数据的地址大( )个字节。

A. 1

B. 2

C. 4

D. 8

28. 假定有定义为“int m=7, *p;”,则给p赋值的正确表达式为()。

A. p=m

B. p=&m

C. *p=&m

D. p=*m

29. 假定指针变量p定义为“int *p=malloc(sizeof(int));”,要释放p所指向的动态存储空间,应调用的函数为()。

A. free(p)

B. delete(p)

C. free(*p)

D. free(&p)

30. C语言中的系统函数fopen()是()一个数据文件的函数。

A. 读取

B. 写入

C. 关闭

D. 打开

参考解答:

1. A

2. B

3. B

4. B

5. D

6. C

7. A

8. C

9. A 10. B

11. B 12. C 13. C 14. A 15. D

16. B 17. B 18. A 19. D 20. C

21. D 22. A 23. A 24. B 25. C

26. C 27. C 28. B 29. A 30. D

二、填空题

1.C语言中的每条简单语句以_;(或分号)作为结束符。

2. C程序中的所有预处理命令均以___#___字符开头。

3. 当不需要函数返回任何值时,则应使用void 标识符来定义函数类型。

4.十进制数25表示成符合C语言规则的十六进制数为0x19

5. 假定不允许使用逻辑非操作符,则逻辑表达式a>b || b==5的相反表达式为a<=b && b!=5

6. 执行“typedef int DataType;”语句后,在使用int定义整型变量的地方也可以使用______ DataType ____来定义整型变量。

7. 假定一维数组的定义为“char* a[8];”,则该数组所占存储空间的字节数为_____32 ___。

8. 假定二维数组的定义为“double a[M][N];”,则该数组的列下标的取值范围在_____0~N-1____之间。

9. 存储一个空字符串需要占用____1 ____个字节。

10. strcpy函数用于把一个字符串_____拷贝(复制)___到另一个字符数组空间中。

11. 程序的编译单位是一个_____程序文件_____。

12. 假定a是一个一维数组,则a[i]的指针访问方式为___*(a+i)_____。

13. 执行int *p=malloc(sizeof(int))操作得到的一个动态分配的整型对象为___*p _____。

14.执行“printf("%c",'A'+2);”语句后得到的输出结果为___ C _____。

15.short int类型的长度为____2 ____。

16. 用类型关键字表示十进制常数3.26f的类型为___ float _____。

17. 假定y=10,则表达式++y*3的值为____ 33____。

18. 逻辑表达式(x==0 && y>5)的相反表达式为_(x!=0 || y<=5) 或:(x || y<=5) _______。

19.若x=5,y=10,则x!=y的逻辑值为____1____。

20. 假定二维数组的定义为“int a[3][5];”,则该数组所占存储空间的字节数为_60 ___。

21. 使用“typedef char BB[10][50];”语句定义___ BB _____为含有10行50列的二维字符数组类型。

22. 字符串"a:\\xxk\\数据"的长度为__11______。

23.假定p所指对象的值为25,p+1所指对象的值为46,则*++p的值为___46 _____。

24. 假定一个数据对象为int*类型,则指向该对象的指针类型为___ int** ____。

25.假定一个结构类型的定义为“struct A{int a,b; A* c;};”,则该类型的长度为_____12 ___。

26. 假定要访问一个结构对象x中的数据成员a,则表示方式为_____ x.a _______。

27. 用于输出表达式值的标准输出函数的函数名是___ printf _____。

28.每个C语言程序文件在编译时可能出现有致命性错误,其对应的标识符为__ error ______。

29. 已知'A'~'Z'的ASCII码为65~90,当执行“int x='C'+3;”语句后x的值为___70_____。

30. 表达式(int)14.6的值为_14_______。

31. 假定不允许使用逻辑非操作符,则关系表达式x+y>5的相反表达式为___ x+y<=5

32. 假定x=5,则执行“a=(x?10:20);”语句后a的值为_10 _______。

33. 假定一维数组的定义为“char* a[M];”,则该数组所占存储空间的字节数为____4*M ____。

34. 存储字符串"a"需要至少占用存储器的____2____个字节。

35. strlen()函数用于计算一个字符串的___长度_____。

36. 在C语言中,一个函数由函数头和____函数体______这两个部分组成。

37.假定p所指对象的值为25,p+1所指对象的值为46,则执行表达式*(p++)后,p所指对象的值为____46____。

38. 假定p是一个指向整数对象的指针,则用___&p _____表示指针变量p的地址。

39. 与结构成员访问表达式p->name等价的访问表达式为_____(*p).name _______。

参考解答:

1. ;(或分号)

2. #

3. void

4. 0x19

5. a<=b && b!=5

6. DataType

7. 32

8. 0~N-1

9. 1 10. 拷贝(复制) 11. 程序文件 12. *(a+i)

13. *p 14. C 15. 2 16. float

17. 33 18. (x!=0 || y<=5) 或:(x || y<=5)

19. 1 20. 60 21. BB 22. 11

23. 46 24. int** 25. 12 26. x.a

27. printf 28. error 29. 70 30. 14

31. x+y<=5 32. 10 33. 4*M 34. 2

35. 长度 360. 函数体 37. 46 38. &p

39. (*p).name

五、按题目要求编写程序或函数

1. 编写一个程序,输出50以内(含50)的、能够被3或者5整除的所有整数。

#include

void main()

{

int i;

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

if(i%3==0 || i%5==0) printf("%d ",i);

printf("\n");

}

2. 编写一个递归函数“int FF(int a[], int n)”,求出数组a 中所有n 个元素之积并返回。

int FF(int a[], int n)

{

if(n<=0) {printf("n 值非法\n"),exit(1);}

if(n==1) return a[n-1];

else return a[n-1]*FF(a,n-1);

}

3. 编写一个程序,利用while 循环,计算并打印输出n

1...31211++++的值,其中正整数n 值由键盘输入。假定求和变量用sum 表示,计数变量用i 表示,sum 、i 和n 均定义为全局变量,sum 和i 的初值分别被赋予0和1。 #include

int n,i=1;

double sum=0;

void main()

{

scanf("%d",&n);

while(i<=n) sum+=(double)1/i++;

printf("sum=%lf\n",sum);

}

4. 根据函数原型“void DD(int a[], int n, int MM)”编写函数定义,利用双重循环查找并打印输出数组a[n]中任何两个元素的值等于MM 值的元素值。假定a[i]+a[j]等于MM ,则输出格式为:(a[i],a[j])。

void DD(int a[], int n, int MM)

{

int i,j;

for(i=0; i

for(j=i+1; j

if(a[i]+a[j]==MM) printf("%d, %d\n", a[i],a[j]);

}

5. 编写一个程序,计算1+3+32+...+310的值并输出,假定分别用i,p,s 作为循环变量、累乘变量和累加变量的

标识符。

#include

void main()

{

int i;

int p=1;

int s=1;

for(i=1;i<=10;i++) {p*=3; s+=p;}

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

}

6. 根据函数原型“int FF(int a[], int n)”,编写函数定义,计算并返回数组a[n]中所有元素之和。

int FF(int a[], int n)

{

int i,sum=0;

for(i=0; i

return sum;

}

7. 根据函数原型“double Mean(double a[M][N],int m,int n)”,编写函数定义,要求返回二维数组a[m][n]中所有元素的平均值。假定在计算过程中采用变量v存放累加值和最后的平均值。

double Mean(double a[M][N],int m,int n)

{

int i,j;

double v=0.0;

for(i=0; i

for(j=0; j

v/=m*n;

return v;

}

注:函数体的最后两行可以合并为一条返回语句:return v/=m*n

8. 根据函数原型“int MM(int a[],int m)”,编写函数定义,计算并返回数组a[m]中元素最大值和最小值之差。

int MM(int a[],int m)

{

int i,x1,x2;

x1=x2=a[0];

for(i=1; i

if(a[i]>x1) x1=a[i];

if(a[i]

}

return x1-x2;

}

相关主题
相关文档
最新文档