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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】国家二级C语言机试(操作题)模拟试卷402及答案解析.doc

1、国家二级 C语言机试(操作题)模拟试卷 402及答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.程序通过定义学生结构体变量,存储了学生的学号、姓名和 3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun的功能是重写形参 filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #defi

2、ne N 53 typedef struct student4 long sno;5 char name10;6 float score3;7 STU;8 void fun(char *filename,STU n)9 FILE*fp;10 *found*11 fp=fopen(_1_,rb+);12 *found*13 fseek(_2_,-(long)sizeof(STU),SEEK_END);14 *found*15 fwrite(n, sizeof(STU), 1,_3_);16 fclose(fp);17 18 main()19 STU tN=10001,MaChao,91,92,7

3、7,10002,CaoKai,75,60,88,10003,LiSi,85,70,78,10004,FangFang,90,82,87,10005,ZhangSan,95,80,88;20 STU n=10006,ZhaoSi,55,70,68,ssN;21 int i,j;FILE *fp;22 fp=fopen(studentdat,wb);23 fwrite(t,sizeof(STU),N,fp);24 fclose(fp);25 fp=fopen(studentdat,rb);26 fread(ss,sizeof(STU),N,fp);27 fclose(fp);28 printf(n

4、The original data:nn);29 for(j=0;jN;j+)30 printf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);31 for(i=0;i3;i+) printf(62f,ssjscorei);32 printf(n);33 34 fun(studentdat,n);35 printf(nThe data after modifing:nn);36 fp=fopen(studentdat,rb);37 fread(ss,sizeof(STU),N,fp);38 fclose(fp);39 for(j=0;jN;j+)40 prin

5、tf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);41 for(i=0;i3;i+)printf(62f,ssjscorei);42 printf(n);43 44 (分数:2.00)_二、程序修改题(总题数:1,分数:2.00)2.给定程序 MODI1C 中函数 fun的功能是:将 s所指字符串中位于奇数位置的字符或 ASCII码为偶数的字符放入 t所指数组中(规定第一个字符放在第 0位中)。 例如,字符串中的数据为:AABBCCDDEEFF,则输出应当是:ABBCDDEFF。 请改正函数 fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动 m

6、ain函数,不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #includestringh3 #define N 804 void fun(char *s,char t)5 int i,j=0;6 for(i=0; i(int)strlen(s); i+)7 *found*8 if(i2si2=0)9 tj+=si;10 *found*11 ti=0;12 13 main()14 char sN,tN;15 printf(nPlease enter strings:);gets(s);16 fun(s,t);17 printf(nThe result is:sn,t)

7、18 (分数:2.00)_三、程序设计题(总题数:1,分数:2.00)3.请编写函数 fun:在形参指针所指的 4个整数中找出最大值和最小值,最大的放在 a中,最小的放在 d中。 注意:部分源程序存在 PROG1C 中,请勿改动主函数 main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。1 #includestdioh2 void NONO();3 void fun(int *a,int *b,int *c,int*d)4 5 6 main()7 int a,b,c,d;8 printf(请输入 4个整数:);9 scanf(dddd,19 fp=fopen(ind

8、at,r);20 wf=fopen(outdat,w);21 for(i=0;i5;i+)22 fscanf(fp,dddd,a,b,c,d);23 fun(a,b,c,d);24 fprintf(wf,a=d,d=dn,a,d);25 26 fclose(fp);27 fclose(wf);(分数:2.00)_国家二级 C语言机试(操作题)模拟试卷 402答案解析(总分:6.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:2.00)1.程序通过定义学生结构体变量,存储了学生的学号、姓名和 3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun的功能是重写形参 fil

9、ename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANK1C 中。 不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #define N 53 typedef struct student4 long sno;5 char name10;6 float score3;7 STU;8 void fun(char *filename,STU n)9 FILE*fp;10 *found*11 fp=fopen(_1_,

10、rb+);12 *found*13 fseek(_2_,-(long)sizeof(STU),SEEK_END);14 *found*15 fwrite(n, sizeof(STU), 1,_3_);16 fclose(fp);17 18 main()19 STU tN=10001,MaChao,91,92,77,10002,CaoKai,75,60,88,10003,LiSi,85,70,78,10004,FangFang,90,82,87,10005,ZhangSan,95,80,88;20 STU n=10006,ZhaoSi,55,70,68,ssN;21 int i,j;FILE *

11、fp;22 fp=fopen(studentdat,wb);23 fwrite(t,sizeof(STU),N,fp);24 fclose(fp);25 fp=fopen(studentdat,rb);26 fread(ss,sizeof(STU),N,fp);27 fclose(fp);28 printf(nThe original data:nn);29 for(j=0;jN;j+)30 printf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);31 for(i=0;i3;i+) printf(62f,ssjscorei);32 printf(n);33

12、 34 fun(studentdat,n);35 printf(nThe data after modifing:nn);36 fp=fopen(studentdat,rb);37 fread(ss,sizeof(STU),N,fp);38 fclose(fp);39 for(j=0;jN;j+)40 printf(nNo:1d Name:-8s Scores:,ssjsno,ssjname);41 for(i=0;i3;i+)printf(62f,ssjscorei);42 printf(n);43 44 (分数:2.00)_正确答案:(正确答案:(1)filename (2)fp (3)f

13、p)解析:解析:第一空:“fp=fopen(_1_,rb+);”补充 fopen的参数,fopen 的调用形式是:fp=fopen(文件名,文件使用方式),因此第一空处应填文件名“filename”。 第二空:此处是补充fseek函数的参数,fseek 的调用形式是:fseek(fp,offset,position),其中第一个参数是文件型指针,故第二空处应填文件型指针变量“fp”。 第三空:fwrite 的调用形式是(buffer,size,count,fp),最后一个参数是文件型指针,故第三空处应填“fp”,将新的学生数据写在最后一个学生数据位置。二、程序修改题(总题数:1,分数:2.00

14、)2.给定程序 MODI1C 中函数 fun的功能是:将 s所指字符串中位于奇数位置的字符或 ASCII码为偶数的字符放入 t所指数组中(规定第一个字符放在第 0位中)。 例如,字符串中的数据为:AABBCCDDEEFF,则输出应当是:ABBCDDEFF。 请改正函数 fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构!1 #includestdioh2 #includestringh3 #define N 804 void fun(char *s,char t)5 int i,j=0;6 for(i=0; i(int)strle

15、n(s); i+)7 *found*8 if(i2si2=0)9 tj+=si;10 *found*11 ti=0;12 13 main()14 char sN,tN;15 printf(nPlease enter strings:);gets(s);16 fun(s,t);17 printf(nThe result is:sn,t);18 (分数:2.00)_正确答案:(正确答案:(1)if(i2si2=0)或 if(i2!=0si2=0) (2)tj=0;或 tj=0;)解析:解析:(1)第一个错误标识下的 if条件应该是判定字符是奇数位置或者 ASCII码是偶数,原题中给出的是字符是奇数

16、位置并且 ASCII码为偶数,逻辑关系表达式不对,应该是或的关系,所以“if(i219 fp=fopen(indat,r);20 wf=fopen(outdat,w);21 for(i=0;i5;i+)22 fscanf(fp,dddd,a,b,c,d);23 fun(a,b,c,d);24 fprintf(wf,a=d,d=dn,a,d);25 26 fclose(fp);27 fclose(wf);(分数:2.00)_正确答案:(正确答案:3 void fun (int *a,int*b,int*c,int*d) 4 int t; 5 if(*ab)t=*a;*a=*b;*b=t; 6 i

17、f(*a*c)(t=*a; *a=*c;*c=t; 7 if(*a*d)t=*a; *a=*d;*d=t; 8 if(*b*c)t=*b; *b=*c;*c=t; 9 if(*b*d)t=*b;*b=*d;*d=t; 10 if(*c*d)t=*c;*c=*d;*d=t; )解析:解析:首先在主函数 main中我们需要的就是四个数字,这四个数字需要手动输入,件程序代码第1315 行,四个数字输入完城后就可以进入 fun函数进行数据处理了。进入到 fun函数中,只要从 a到d进行比较,按照一开始的规则即可,如果 a大于 b,不变,比较 a与 c,若 a小 b,a 与 b交换位置,交换过后 a就大于 b了,这样就进行 a与 c的比较;a 与 c的比较同理,这样的循环比较,就能发现,每比较一次,较大的数字就能交换到 a的位置,较小的数字就离 a越来越远,也就是到了 d的位置,这样就完成了题目所给出的要求了,最大的数字放在 a中,最小的数字放在 d中。当新的排序排好后,就可以返回主函数进行输出了。

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