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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】三级数据库技术机试-222及答案解析.doc

1、三级数据库技术机试-222 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.请编制一个函数 arrange(int inBuf109),其功能是:将一正整数序列 K1,K 2,K 9重新排成一个新的序列。新序列中,比 K1小的数都在 K1的左面(后续的再向左存放),比 K1大的数都在K1的右面(后续的再向右存放),从 K1向右扫描。函数 WriteData()负责将 outBuf中的数据输出到文件 OUT.DAT 中。说明:在程序中已给出了 10 个序列,每个序列中有 9 个正整数,并存入数组 inBufE109中,分别求出这 10 个新序

2、列。例如:序列排序前 3,5,8,9,1,2,6,4,7序列排序后 2,1,3,5,8,9,6,4,7注意:部分源程序已给出。请勿改动主函数 main()和写函数 WriteData()的内容。试题程序:#includestdio.hvoid writeData();int inBuf109=6,8,9,1,2,5,4,7,3,3,5,8,9,1,2,6,4,7),8,2,1,9,3,5,4,6,7),3,5,1,2,9,8,6,7,4),4,7,8,9,1,2,5,3,6),4,7,3,5,1,2,6,8,9),9,1,3,5,8,6,2,4,7),2,6,1,9,8,3,5,7,4,5,3

3、7,9,1,8,2,6,4,7,1,3,2,5,8,9,4,6,;void arrangeValue()void main()int i,j;arrangeValue();for(i=0;i10;i+)for(i=0;i9;i+)printf(”%d”,inBufij);if(j=7)printf(“,“);printf(“n“);writeData();void writeData()FILE*fp;int i,j;fp=fopen(“OUT.DAT“,“w“);for(i=0;i10;i+)for(j=0, j9;j+)fprintf(fp,“%d“,inBufij);if(j=7)fp

4、rintf(fp,“,“);fprintf(fp,“/n“);fclose(fp);(分数:100.00)_三级数据库技术机试-222 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.请编制一个函数 arrange(int inBuf109),其功能是:将一正整数序列 K1,K 2,K 9重新排成一个新的序列。新序列中,比 K1小的数都在 K1的左面(后续的再向左存放),比 K1大的数都在K1的右面(后续的再向右存放),从 K1向右扫描。函数 WriteData()负责将 outBuf中的数据输出到文件 OUT.DAT 中。说明:在程序中已给

5、出了 10 个序列,每个序列中有 9 个正整数,并存入数组 inBufE109中,分别求出这 10 个新序列。例如:序列排序前 3,5,8,9,1,2,6,4,7序列排序后 2,1,3,5,8,9,6,4,7注意:部分源程序已给出。请勿改动主函数 main()和写函数 WriteData()的内容。试题程序:#includestdio.hvoid writeData();int inBuf109=6,8,9,1,2,5,4,7,3,3,5,8,9,1,2,6,4,7),8,2,1,9,3,5,4,6,7),3,5,1,2,9,8,6,7,4),4,7,8,9,1,2,5,3,6),4,7,3,

6、5,1,2,6,8,9),9,1,3,5,8,6,2,4,7),2,6,1,9,8,3,5,7,4,5,3,7,9,1,8,2,6,4,7,1,3,2,5,8,9,4,6,;void arrangeValue()void main()int i,j;arrangeValue();for(i=0;i10;i+)for(i=0;i9;i+)printf(”%d”,inBufij);if(j=7)printf(“,“);printf(“n“);writeData();void writeData()FILE*fp;int i,j;fp=fopen(“OUT.DAT“,“w“);for(i=0;i10

7、i+)for(j=0, j9;j+)fprintf(fp,“%d“,inBufij);if(j=7)fprintf(fp,“,“);fprintf(fp,“/n“);fclose(fp);(分数:100.00)_正确答案:(davoid arrangeValue()int i,j,temp9,num_low,num_high;for(i+0;i10;i+) /对 10 行数据进行扫描num_low=0,num_high=8;for(j=8;j=0;j)/从最后一列向前扫描if(inBufijinBufi0)/如果当前数据比首位数据大tempnum_high=inBufij;/将当前数据放到

8、temp 中的第 num_high 位num_high; /将存放比首位数据大的数据的下标前移,以指定下次存放的位置elsetempnum_low=inBufij;/将当前数据放到 temp 中的第 num_low 位hum_low+; /将存放比首位数据小的数据的下标后移,以指定下次存放的位置tempnum_high=inBufi0; /将最后留下的位置上存放原数组的首位数据for(j=0;j9;j+)inBufij=tempij;/将 temp 中的内容复制到 inBuf 中)解析:解析 本题主要考查数组中数据按指定要求重新排序的方法。从左边开始扫描时,不管是比第一个大的还是小的,都以第一个元素所在的位置来确定起始位置,由于第一个元素的位置不确定,所以比第一个元素大的和小的元素的起始存放位置也不能确定。若从右侧开始扫描,则比第一个元素大的和小的元素的起始存放位置是数组的两侧,起始位置固定。程序步骤:从右侧开始查找,如果当前元素比第一个元素大,则从数组 temp 的右侧起存放,反之,则从数组 temp 的左侧起存放,最后将第一个元素存放在剩下的位置;将 temp 中的值赋给数组 inBuf。

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