ImageVerifierCode 换一换
格式:DOC , 页数:6 ,大小:35KB ,
资源ID:1325360      下载积分:5000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
注意:如需开发票,请勿充值!
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-1325360.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(【计算机类职业资格】二级C语言-394及答案解析.doc)为本站会员(jobexamine331)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

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

1、二级 C 语言-394 及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.函数 fun 的功能是:输出 a 所指数组中的前 n 个数据,要求每行输出 5 个数。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #includestdlib.h void fun(int*a,int n) int i; for(i=0;in;i+) /*found*/ if( 1=0) /*found*/ printf(“ 2“); /*found

2、*/ printf(“%d“, 3); inain() int a100=0,i,n; n=22; for(i=0;in;i+) ai=rand()%21; fun(a,n); printf(“/n“); (分数:30.00)二、程序修改题(总题数:1,分数:30.00)2.给定程序中,fun 函数的功能是:在任意给定的 N 个正整数中,从左到右依次逐个取三个数作为一组,按值大小找出该组数的中值,用该中值替换与该组数对应的原三个数中的中间位置的数。处理后原数列中首尾 2 个数不变。处理后数列在主函数中输出。例如,有 10 个正整数如下: 初始数列为:6 5 7 23 18 5 8 21 45

3、38 第 1 组数为:6 5 7 中值为:6 替换后的数列为: 6 6 7 23 18 5 8 21 45 38 第 2 组数为:5 7 23 中值为:7 替换后的数列为:6 6 7 23 18 5 8 21 45 38 第 3 组数为:7 23 18 中值为:18 替换后的数列为:6 6 7 18 18 5 8 21 45 38 第 4 组数为:23 18 5 中值为:18 替换后的数列为:6 6 7 18 18 5 8 21 45 38 第 5 组数为:18 5 8 中值为:8 替换后的数列为:6 6 7 18 18 8 8 21 45 38 第 6 组数为:5 8 21 中值为:8 替换

4、后的数列为:6 6 7 18 18 8 8 21 45 38 第 7 组数为:8 21 45 中值为:21 替换后的数列为:6 6 7 18 18 8 8 21 45 38 第 8 组数为:21 45 38 中值为:38 替换后的数列为:6 6 7 18 18 8 8 21 38 38 最终结果为:6 6 7 18 18 8 8 21 38 38 请改正程序中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #define N 10 int findmid(int a,int b,int

5、c) int t; t=(ab)? (bc? b:(ac? c:a):(ac)?a:(bc)?c:b); /*found*/ return b; void fun(int x) int i,a,b,c,tN; /*found*/ for(i=0;iN;i+)ti=xi for(i=0;iN-2;i+) a=ti;b=ti+1;c=ti+2; /*found*/ ti+1=findmid(a,b,c); main() int i,xN=6,5,7,23,18,5,8,21,45,38; for(i=0;iN;i+) printf(“%d“,xi); printf(“/n“); fun(x); f

6、or(i=0;iN;i+) printf(“%d“,xi); printf(“/n“); (分数:30.00)三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,函数的功能是查找 x 在 s 所指数组中下标的位置,并作为函数值返回,若 x 不存在,则返回-1。 注意:请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入你编写的若干语句。试题程序: #includestdio.h #includestdlib.h #define N 15 void NONO(); int fun (int*s,int x) main() int aN=29,13,

7、5,22,10,9,3,18,22,25,14,15,2,7,27,i,x, index; printf(“a 数组中的数据:/n“); for(i=0;iN;i+) printf(“%4d“,ai); printf(“/n“); printf(“给 x 输入待查找的数:“); scanf(“%d“, index=fun(a,x); printf(“index=%d/n“,index); NONO(); void NONO() /*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/ FILE*fp,*wf; int i,j,a10,x,index; fp=fopen(“in.da

8、t“,“r“); wf=fopen(“out.dat“,“w“); for(i=0;i10;i+) for(j=0;j10;j+) fscanf(fp,“%d“, fscanf(fp,“%d“, index=fun(a,x); fprintf(wf,“%d/n“,index); fclose(fp); fclose(wf); (分数:40.00)_二级 C 语言-394 答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.函数 fun 的功能是:输出 a 所指数组中的前 n 个数据,要求每行输出 5 个数。 请在程序的下画线处填入正确的内容并把

9、下画线删除,使程序得出正确的结果。 注意:不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #includestdlib.h void fun(int*a,int n) int i; for(i=0;in;i+) /*found*/ if( 1=0) /*found*/ printf(“ 2“); /*found*/ printf(“%d“, 3); inain() int a100=0,i,n; n=22; for(i=0;in;i+) ai=rand()%21; fun(a,n); printf(“/n“); (分数:30.00)解析:(1)i%5 (2)

10、/n (3)ai 解析 填空 1:每行输出 5 个数,即当下标值能整除 5 时换行。 填空 2:输出换行符“/n“。 填空 3:输出数组元素。二、程序修改题(总题数:1,分数:30.00)2.给定程序中,fun 函数的功能是:在任意给定的 N 个正整数中,从左到右依次逐个取三个数作为一组,按值大小找出该组数的中值,用该中值替换与该组数对应的原三个数中的中间位置的数。处理后原数列中首尾 2 个数不变。处理后数列在主函数中输出。例如,有 10 个正整数如下: 初始数列为:6 5 7 23 18 5 8 21 45 38 第 1 组数为:6 5 7 中值为:6 替换后的数列为: 6 6 7 23 1

11、8 5 8 21 45 38 第 2 组数为:5 7 23 中值为:7 替换后的数列为:6 6 7 23 18 5 8 21 45 38 第 3 组数为:7 23 18 中值为:18 替换后的数列为:6 6 7 18 18 5 8 21 45 38 第 4 组数为:23 18 5 中值为:18 替换后的数列为:6 6 7 18 18 5 8 21 45 38 第 5 组数为:18 5 8 中值为:8 替换后的数列为:6 6 7 18 18 8 8 21 45 38 第 6 组数为:5 8 21 中值为:8 替换后的数列为:6 6 7 18 18 8 8 21 45 38 第 7 组数为:8 2

12、1 45 中值为:21 替换后的数列为:6 6 7 18 18 8 8 21 45 38 第 8 组数为:21 45 38 中值为:38 替换后的数列为:6 6 7 18 18 8 8 21 38 38 最终结果为:6 6 7 18 18 8 8 21 38 38 请改正程序中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #define N 10 int findmid(int a,int b,int c) int t; t=(ab)? (bc? b:(ac? c:a):(ac)?a:

13、(bc)?c:b); /*found*/ return b; void fun(int x) int i,a,b,c,tN; /*found*/ for(i=0;iN;i+)ti=xi for(i=0;iN-2;i+) a=ti;b=ti+1;c=ti+2; /*found*/ ti+1=findmid(a,b,c); main() int i,xN=6,5,7,23,18,5,8,21,45,38; for(i=0;iN;i+) printf(“%d“,xi); printf(“/n“); fun(x); for(i=0;iN;i+) printf(“%d“,xi); printf(“/n“

14、); (分数:30.00)解析:(1)return t; (2)for(i=0;iN;i+)ti=xi; (3)xj+1=findmid(a,b,c); 解析 (1)函数 findmid 的功能是找到 a、b、c 三个数中的中间数,并存放在变量 t 中,因此应返回 t。 (2)语法错误,句末缺少分号。 (3)本程序是对数组 x 进行操作,数组 t 只是用来暂时存放数组 x 中的元素,因此此处应为 xi+1=findmid(a,b,c)。三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,函数的功能是查找 x 在 s 所指数组中下标的位置,并作为函数值返回,若 x 不存在,则返

15、回-1。 注意:请勿改动主函数 main 和其他函数中的任何内容,仅在函数 fun 的花括号中填入你编写的若干语句。试题程序: #includestdio.h #includestdlib.h #define N 15 void NONO(); int fun (int*s,int x) main() int aN=29,13,5,22,10,9,3,18,22,25,14,15,2,7,27,i,x, index; printf(“a 数组中的数据:/n“); for(i=0;iN;i+) printf(“%4d“,ai); printf(“/n“); printf(“给 x 输入待查找的数

16、:“); scanf(“%d“, index=fun(a,x); printf(“index=%d/n“,index); NONO(); void NONO() /*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。*/ FILE*fp,*wf; int i,j,a10,x,index; fp=fopen(“in.dat“,“r“); wf=fopen(“out.dat“,“w“); for(i=0;i10;i+) for(j=0;j10;j+) fscanf(fp,“%d“, fscanf(fp,“%d“, index=fun(a,x); fprintf(wf,“%d/n“,index); fclose(fp); fclose(wf); (分数:40.00)_正确答案:()解析:int fun(int*s,int x) int i; for(i=0;iN;i+) if(x=si)return i; return-1; 解析 要找出数组中指定数据的下标,首先定义变量 i 用于存放数组下标,然后使用循环语句对数组进行遍历,依次取出一个数组元素与指定的数进行比较,若相等,则返回该元素的下标,否则继续判断下一个元素,直到数组结束。若数组结束时仍没有找到与指定数相等的元素,则返回-1。

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