十进制数25表示成符合c语言规则的十六进制数为,2019电大开放教育C语言程序设计课程期末复习考试题库必考重点...

这是一份关于C语言程序设计的期末复习资料,包含了选择题、填空题及编程题,涵盖数组、指针、函数、内存管理等多个核心知识点,如二维数组的元素访问、函数原型、指针运算、预处理命令、字符串处理等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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 _____。

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. 字符串\数据\的长度为__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. 存储字符串\需要至少占用存储器的____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(\ printf(\ }

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

int FF(int a[], int n)

{

if(n<=0) {printf(\值非法\\n\ if(n==1) return a[n-1]; else return a[n-1]*FF(a,n-1); }

3. 编写一个程序,利用while循环,计算并打印输出1?111??...?的值,其中正整数n值由键盘输入。假定23n求和变量用sum表示,计数变量用i表示,sum、i和n均定义为全局变量,sum和i的初值分别被赋予0和1。

#includeint n,i=1; double sum=0; void main() {

scanf(\

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

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; ifor(j=i+1; jif(a[i]+a[j]==MM) printf(\ }

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(\ }

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

int FF(int a[], int n) {

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值