电大本科C语言程序设计A期末考试复习资料
本科《C语言程序设计A》复习资料
C. strcat() D. strcmp()
一、单选题
1.在每个C语言程序中都必须包含有这样一个函数,该函数的函数名为(A)。
A. main B. MAIN C. name D. function
2.每个C语言程序文件的编译错误分为(B)类。
7. 若用数组名作为函数调用的实参,传递给形参的是(A)。
A. 数组的首地址 B. 数组中第一个元素的值
C. 数组中全部元素的值 D. 数组元素的个数
8. 假定a为一个整数类型的数组名,整数
A. 1 B. 2 C. 3 类型的长度为4,则元素a[4]的地址比aD. 4
3. 字符串\的长度为(B)。 A. 6 B. 7 C. 8 D. 9 4. 在switch语句的每个case块中,假定都是以break语句结束的,则此switch语句容易被改写为(D)语句。 A. forB. whileC. doD. if
5. 在下面的do-while循环语句中,其循环体语句被执行的次数为(C)。
int i=0; do i++; while(i<10); A. 8 B. 9 C. 10 D. 11 6. 将两个字符串连接起来组成一个字符串时,选用的字符串函数为(C)。 A. strlen() B. strcpy()
1 / 19
数组的首地址大(C)个字节。
A. 4 B. 8 C. 16 D. 32
9. 假定s被定义为指针类型char *的变量,初始指向的字符串为\,若要使变量p指向s所指向的字符串,则p应定义为(A)。
A. char *p=s; B. char *p=&s; C. char *p;p=*s; D. char *p; p=&s;
10. 从一个数据文件中读入以换行符结束的一行字符串的函数为(B)。
A. gets() B. fgets()
C. getc() D. fgetc()
电大本科C语言程序设计A期末考试复习资料
11.程序运行中需要从键盘上输入多于一个数据时,各数据之间默认使用(D)符号作为分隔符。
A.2 B.4 C.6 D.8
16.在下列选项中,不正确的函数原型格
A.空格或逗号 B.逗号或回车 式为( C)。
C.逗号或分号 D.空格或回车
12.逻辑表达式(x>0 && x<=10)的相反表达式为(A)。 A
.
x<=0
||
A.int Function(int a); B.void Function (char); C
.
int
Function(a);
x>10 D.void int(double* a);
17.假定p是一个指向float型数据的指
B.x<=0 && x>10 C
.
x<=0
||
x<=10 针,则p+1所指数据的地址比p所指数据
的地址大(C)个字节。
D.x>0 && x>10
13.当处理特定问题时的循环次数已知时,通常采用(A)循环来解决。
A.1 B.2 C.4 D.8
A.for B.while C.do-while 18.假定有定义为“int m=7, *p;”,则给D.switch
14.假定i的初值为0,则在循环语句“while(i
p赋值的正确表达式为(B)。
A.p=m B.p=&m C.*p=&m D.p=*m
19.假定指针变量p定义为“int
A.n-1 B.n C.n+1 *p=malloc(sizeof(int));”,要释放p所D.n/2
15.假定一个二维数组的定义语句为“int a[3][4]={{3,4},{2,8,6}};”,则元素a[1][2]的值为(C)。
指向的动态存储空间,应调用的函数为(A)。
A.free(p) B.delete(p) C.free(*p) D.free(&p)
2 / 19
电大本科C语言程序设计A期末考试复习资料
20.C语言中的系统函数fopen()是( D)一个数据文件的函数。
A.读取 B.写入 C.关闭 D.打开
21. C语言源程序文件的缺省扩展名为(D)。
C. int a[] D. int a[5]
26.下面的函数原型声明中存在语法错误的是(C)。
A. AA(int a, int b)
A. cpp B. exe C. obj B. AA(int, int) D. C
22.设x和y均为逻辑值,则x&&y为真的条件是(A)。
A. 它们均为真 B. 其中一个为真 C. 它们均为假 D. 其中一个为假 23. 在下列的符号常量定义中,正确的定义格式为(C)。
A. #define M1 B. const int M2 20
C. #define M3 10 D. const char mark
24. for循环语句能够被改写为(D)语句。 A. 复合 B. ifC.switchD. while 25. 在下面的一维数组定义中,错误的定义格式为(C)。
A. int a[]={1,2,3} B. int a[10]={0}
C. AA(int a; int b;) D. AA(int a, int)
27. 假定a为一个数组名,则下面存在错误的表达式为的(B)。
A. a[i] B. *a++ C. *a D. *(a+1)
28. 假定有定义为“int a[10], x, *pa=a;”,若要把数组a中下标为3的元素值赋给x,则不正确的赋值为(D)。
A. x=pa[3] B. x=*(a+3)
C. x=a[3] D. x=*pa+3
29.char类型的长度为(A)个字节。
A. 1 B. 2 C. 3 D. 4
30. 向一个二进制文件中写入信息的函数为(D)。
A. fgets() B. fputs()
3 / 19
电大本科C语言程序设计A期末考试复习资料
C. fread() D. fwrite()
31. 由C语言目标文件连接而成的可执行文件的缺省扩展名为(B)。
A. cpp B. exe C. obj D. c
32. 设有两条语句为“int a=12; a+=a*a;”,则执行结束后,a的值为(C)。 A. 12 B. 144 C. 156 D. 288
33. 带有随机函数调用的表达式rand() 的值在(C)区间内。
36. 若有一个函数原型为“double *function()”,则它的返回值类型为(B)。 A. 实数型 B. 实数指针型
C. 函数指针型 D. 数组型
37. 在C语言中,所有预处理命令都是以(B)符号开头的。(B)
A. * B. # C. & D. @ 38. 假定整数指针p所指数据单元的值为30,p+1所指数据单元的值为40,则执行*p++后,p所指数据单元的值为(A)。
A. 40 B. 30 C. 70
A. 1~19 B. 1~20 C.0~19 D. D. 10 0~20
34. for循环语句“for(i=0; i
39. 若要使p指向二维整型数组a[10][20],则p的类型为(D)。
A. int * B. int ** C. int
A. (n+1)/2 B. n/2+1 C. n/2-1 D. *[20] D. int(*)[20] n-1
35. 在下列的字符数组定义中,存在语法错误的是(D)。
A. char a[20]=\char a[]=\
40. 表示文件结束符的符号常量为(C)
A. eof B. Eof C. EOF D. feof
41. C语言程序中的基本功能模块为(D)。 A.表达式 B.标识符 c.语句 D.函数
C. char a[15]={'1','2'}; D. 42.逻辑表达式(x>0||y==5)的相反表达式char a[10]='5';
为(B)。
4 / 19
电大本科C语言程序设计A期末考试复习资料
A.x<=O||y!=5 B.x<=O&&y!=5 49.十进制数 50表示成符合C语言规定的
八进制数为(D)。
A. 20 B.32 C.62 D.062
50.若要以读和写两种操作方式打开一个二进制文件,当文件不存在时返回打开失败信息,则选用的打开方式字符串为(C)。 A.\
C.x>O||y!=5 D.x>O&&y==5
43.循环体至少被执行一次的循环语句为 (C)。
A.for B.while C.do-while D.任一种循环
44.假定 n的值为5,则表达式n++的值为(B)。
A.6 B.5 C.4 D.7
二、填空题
1.在一个C语言程序文件中,若要包含另
45.假定一个二维数组的定义为\
外一个头文件或程序文件,则应使用的预
a[3][4]={{3,4},{2,8,6}}号\,则元素
处理命令为(#include )
a[2][O]值为(A)。
2.用于从键盘上为变量输入值的标准输入
A.0 B.2 C.4 D.6
函数的函数名为(scanf)
46.假定一个函数原型为\
3.假定一个枚举类型的定义为\
n)\,则该函数的返回类型为(D)。
RA{ab,ac,ad,ae};\,则ac的值为(1)
A. int B. int* c.char D.char*
4. double类型的长度为(8)
47.假定a为一个字符数组名,则元素a[i]
5.执行\,
的指针访问方式为(B)。
x/y);\语句序列后得到的输出结果为(3)
A.a+i B.*(a+i) C.&a+i D.*a+i
6.把表达式x=x+y转换成复合赋值表达式
48.假定有语句为\,
为(x+=y)
sizeof(int)),则p所指向的动态数组中
7.假定
所包含的元素个数为(C)。
\语句后a的值为(20)
A.10 B.20 c.30 D.40
5 / 19
x
的值为
5,则执行