资源描述
资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
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<n; i+=2) S;”中循环体S语句被执行的次数为( ) 。
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<n) {s+=i*i; 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<stdio.h>
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值由键盘输入。假定求和变量用sum表示, 计数变量用i表示, sum、 i和n均定义为全局变量, sum和i的初值分别被赋予0和1。
#include<stdio.h>
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<n; i++)
for(j=i+1; j<n; j++)
if(a[i]+a[j]==MM) printf("%d, %d\n", a[i],a[j]);
}
5. 编写一个程序, 计算1+3+32+...+310的值并输出, 假定分别用i,p,s作为循环变量、 累乘变量和累加变量的标识符。
#include<stdio.h>
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<n; i++) sum+=a[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<m; i++)
for(j=0; j<n; j++) v+=a[i][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<m; i++) {
if(a[i]>x1) x1=a[i];
if(a[i]<x2) x2=a[i];
}
return x1-x2;
}
展开阅读全文