【计算机类职业资格】二级C语言-194 (1)及答案解析.doc

上传人:proposalcash356 文档编号:1324986 上传时间:2019-10-17 格式:DOC 页数:6 大小:32KB
下载 相关 举报
【计算机类职业资格】二级C语言-194 (1)及答案解析.doc_第1页
第1页 / 共6页
【计算机类职业资格】二级C语言-194 (1)及答案解析.doc_第2页
第2页 / 共6页
【计算机类职业资格】二级C语言-194 (1)及答案解析.doc_第3页
第3页 / 共6页
【计算机类职业资格】二级C语言-194 (1)及答案解析.doc_第4页
第4页 / 共6页
【计算机类职业资格】二级C语言-194 (1)及答案解析.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

1、二级 C 语言-194 (1)及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.请补充函数 proc(),该函数的功能是:从键盘输入一个下标 n,把数组 arr 中比元素 arrn小的元素放在它的左边,比它大的元素放在它的右边,排列成的新数组仍然保存在原数组中。 例如,数组 arr=33,67,42,58,25,76,85,16,41,65,输入 3。 结果输出“33,42,25,16,41,58,67,76,85,65”。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的横线上填入所编

2、写的若干表达式或语句。 试题程序: #includestdlib.h #includestdio.h #define M 10 void proc(int arr,int n) int i,j=0,k=0,t; int bbM; t=arrn; for(i=0;iM;i+) if(arrit) bbj+=arri; if(arrit) arrk+=arri; 1; for(i=0; 2;i+,k+) arrk=bbi; void main() int i,n; int arrM=33,67,42,58,25,76,85,16,41,65; system(“CLS“); printf(“/n*o

3、riginal list*/n“); for(i=0;iM;i+) printf(“%4d“,arri); printf(“n suffix n/n“); scanf(“%d“, proc(arr,n); printf(“/n*new list*/n“); for(i=0;iM;i+) printf(“%4d“,arri); (分数:30.00)二、程序改错题(总题数:1,分数:30.00)2.以下程序可把输入的十进制数以十六进制数的形式输出。 请在横线上填上适当的内容并把横线删除,使它能得出正确的结果。 注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。 试题程序: #

4、includestdio.h void main() char b17=“0123456789ABCDEF“; int c64,d,i=0,base=16; long mum; printf(“Enter a number:/n“);scanf(“%1d“,i+;num=num/base; while(num!=0); printf(“Transmite new base:/n“); for(-i:i2=0:-i) /*found* d=ci;printf(“%c“,b 2); printf(“/n“); (分数:30.00)三、程序设计题(总题数:1,分数:40.00)3.请编写函数 pro

5、c(),它的功能是:求出 11000 中能被 5 或 13 整除,但不能同时被 5 和 13 整除的所有整数,并将它们放在 arr 所指的数组中,通过 n 返回这些数。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的花括号中填入所编写的若干语句。 试题程序: #includeconio.h #includestdio.h #includestdlib.h void proc(int*arr,int*n) void main() int arr1000,n,k; system(“CLS“); proc(arr, for(k=0;kn;k+)

6、 if(k+1)%10=0) printf(“%5d“,arrk); printf(“/n“);/一行写 10 个数 else printf(“%5d“,arrk); (分数:40.00)_二级 C 语言-194 (1)答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.请补充函数 proc(),该函数的功能是:从键盘输入一个下标 n,把数组 arr 中比元素 arrn小的元素放在它的左边,比它大的元素放在它的右边,排列成的新数组仍然保存在原数组中。 例如,数组 arr=33,67,42,58,25,76,85,16,41,65,输入 3。 结

7、果输出“33,42,25,16,41,58,67,76,85,65”。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的横线上填入所编写的若干表达式或语句。 试题程序: #includestdlib.h #includestdio.h #define M 10 void proc(int arr,int n) int i,j=0,k=0,t; int bbM; t=arrn; for(i=0;iM;i+) if(arrit) bbj+=arri; if(arrit) arrk+=arri; 1; for(i=0; 2;i+,k+) arrk

8、=bbi; void main() int i,n; int arrM=33,67,42,58,25,76,85,16,41,65; system(“CLS“); printf(“/n*original list*/n“); for(i=0;iM;i+) printf(“%4d“,arri); printf(“n suffix n/n“); scanf(“%d“, proc(arr,n); printf(“/n*new list*/n“); for(i=0;iM;i+) printf(“%4d“,arri); (分数:30.00)解析:arrk+=t ij解析 程序中首先将小于 arrn的 k

9、 个元素放入数组 arr 的前 k 个位置,将大于 arrn的 j 个元素放入临时数组 bb 中。然后将 arrn放入第 k+1 个位置。因此,第一处填“arrk+=t”;最后将大于 arrn的 k 个元素放入数组 arr 中。因此,第二处填“ij”。二、程序改错题(总题数:1,分数:30.00)2.以下程序可把输入的十进制数以十六进制数的形式输出。 请在横线上填上适当的内容并把横线删除,使它能得出正确的结果。 注意:不要改动 main()函数,不得增行或删行,也不得更改程序的结构。 试题程序: #includestdio.h void main() char b17=“0123456789A

10、BCDEF“; int c64,d,i=0,base=16; long mum; printf(“Enter a number:/n“);scanf(“%1d“,i+;num=num/base; while(num!=0); printf(“Transmite new base:/n“); for(-i:i2=0:-i) /*found* d=ci;printf(“%c“,b 2); printf(“/n“); (分数:30.00)解析:错误:缺少语句 正确:应填入 num%base 错误:缺少语句 正确:应填入d 解析 按题目中的要求把输入的十进制数以十六进制数的形式输出,首先要对十进制数对

11、 16 求余,得出十六进制每一位上的数字。因此,ci= -|_|-处填 num%base。数组b 为十进制数 015 所对应的十六进制数,数组 c 中存放的是十六进制数每一位上的数字。因此 b -|_|-处填d。三、程序设计题(总题数:1,分数:40.00)3.请编写函数 proc(),它的功能是:求出 11000 中能被 5 或 13 整除,但不能同时被 5 和 13 整除的所有整数,并将它们放在 arr 所指的数组中,通过 n 返回这些数。 注意:部分源程序给出如下。 请勿改动 main()函数和其他函数中的任何内容,仅在函数 proc()的花括号中填入所编写的若干语句。 试题程序: #i

12、ncludeconio.h #includestdio.h #includestdlib.h void proc(int*arr,int*n) void main() int arr1000,n,k; system(“CLS“); proc(arr, for(k=0;kn;k+) if(k+1)%10=0) printf(“%5d“,arrk); printf(“/n“);/一行写 10 个数 else printf(“%5d“,arrk); (分数:40.00)_正确答案:()解析:void proc(int*arr,int*n) int i,j=0; for(i=1;i=1000;i+) if(i%5=0|i%13=0) /把符合条件的放到 a 数组中, *n=j; /最后把其个数通过形参中的指针变量带回到主函数中 解析 题目中要求出 11000 中能被 5 或 13 整除,但不能同时被 5 和 13 整除的所有整数,首先应判断 11000 的每一个整数是否符合要求,将符合要求的每一个整数放入数组 arr 中。最后将整数的个数作为形参返回给主函数。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1