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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】三级信息管理技术机试-16及答案解析.doc

1、三级信息管理技术机试-16 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 readDat()是从文件 in71.dat中读取 20行数据存放到字符串数组 xx中(每行字符串长度均小于 80)。请编制函数 jsSon(),其功能是:以行为单位对字符串按下面给定的条件进行排序,排序后的结果仍按行重新存入字符串数组 xx中。最后调用函数 writeDat()把结果 xx输出到文件 out71.dat中。条件:从字符串中间一分为二,左边部分按字符的 ASC值降序排序,右边部分按字符的 ASC值升序排序。如果原字符串长度为奇数,则最中间的字符

2、不参加排序,字符仍放在原位置上。例如: 位置 0 1 2 3 4 5 6 7 8源字符串 a b c d h g f e1 2 3 4 9 8 7 6 5处理后的字符串 d c b a e f g h4 3 2 1 9 5 6 7 8注意:部分源程序已给出。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio. h# inc lude st ring. h#inc ludeconio, hchar xx20 80;void jsSort()void main ( )readDat ();jsSort ();write

3、Dat ( );readDat ( )FILE *in;int i=0;char *p;in=fopen ( “in71.dat“, “r“);while (i20 if(p)*p=0;i+;fclose (in);writeDat ( )FILE *out;int i;clrscr ( );out=fopen ( “out71.dat“, “w“ );for (i=0; i20; i+)printf(“%s/n“,xxi);fprintf (out, “%s/n“ ,xxi );fclose (out);(分数:100.00)_三级信息管理技术机试-16 答案解析(总分:100.00,做题时

4、间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 readDat()是从文件 in71.dat中读取 20行数据存放到字符串数组 xx中(每行字符串长度均小于 80)。请编制函数 jsSon(),其功能是:以行为单位对字符串按下面给定的条件进行排序,排序后的结果仍按行重新存入字符串数组 xx中。最后调用函数 writeDat()把结果 xx输出到文件 out71.dat中。条件:从字符串中间一分为二,左边部分按字符的 ASC值降序排序,右边部分按字符的 ASC值升序排序。如果原字符串长度为奇数,则最中间的字符不参加排序,字符仍放在原位置上。例如: 位置 0 1 2 3 4

5、5 6 7 8源字符串 a b c d h g f e1 2 3 4 9 8 7 6 5处理后的字符串 d c b a e f g h4 3 2 1 9 5 6 7 8注意:部分源程序已给出。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio. h# inc lude st ring. h#inc ludeconio, hchar xx20 80;void jsSort()void main ( )readDat ();jsSort ();writeDat ( );readDat ( )FILE *in;int i

6、0;char *p;in=fopen ( “in71.dat“, “r“);while (i20 if(p)*p=0;i+;fclose (in);writeDat ( )FILE *out;int i;clrscr ( );out=fopen ( “out71.dat“, “w“ );for (i=0; i20; i+)printf(“%s/n“,xxi);fprintf (out, “%s/n“ ,xxi );fclose (out);(分数:100.00)_正确答案:(void jsSort()int i,j,k, strl,half;char ch;for (i=O; i20; i+

7、)strl=strlen (xx i ); /*求各行字符串的总长度*/half=strl/2; /*求总长度的一半*/for (j=0; jhalf.-1; j +) /*左边部分按字符的 ASCII值降序排序*/for (k=j+l ;khalf; k+)if(xxi jxxi k)ch=xxi j;xxi j=xxi k;xxi k =ch;if(strl%2) /*如果原字符串长度为奇数,则跳过最中间的字符,使之不参加排序*/half+;for (j=half; jstrl-1; j +) /*右边部分按字符的 ASCII值升序排序*/for (k=j+l ;kstrl ;k+)if(

8、xxi jxxi k)ch=xxi j;xxi j=xxi k;xxi k =ch;)解析:解析 本题考查的知识点如下:(1)二维数组的访问和下标的控制。(2)字符的 ASC码的比较。(3)字符的排序。本题将数据按行存入到二维数组 xx中,行数为数组的第 1个下标,每行字符的个数为数组的第 2个下标。因为以行为字符串处理的单位,所以要先求得一行字符串的长度。字符可以参加任何整数运算,实际上是字符的 ASC码参与了运算,所以可以直接使用比较运算符对字符进行比较。对从 0到(长度/2-1)的字符进行降序排序(数组的下标从 0开始)。若长度为奇数,则再从(长度/2+1)开始(跳过最中间的字符)到最后1个字符进行升序排列。否则,从(长度/2)开始到最后 1个字符进行升序排列。字符排序使用“选择排序法”,最后使用循环实现对每行数据的处理。

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