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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、三级数据库技术机试-212 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.文件 IN.DAT 中存有 200 个 4 位整型数,函数 ReadData()负责将 IN.DAT 中的数读到数组 inBuf中。请编写函数 findValue(),其功能是:求出千位数字上的值加十位数字上的值等于百位数字上的值减上个位数字上的值,并且此 4 位数是偶数的数,用 count 记录下符合条件的数的个数并按照从小到大的顺序存入数组 outBuf中。函数 WriteData()负责将 outBuf中的数输出到文件 OUT.DAT 中并且在屏幕上显示出来。

2、注意:部分源程序已给出。程序中已定义数组:inBuf200,outBuf200,已定义变量:count。请勿改动主函数 main()、读函数 ReadData()和写函数 WriteData()的内容。试题程序:#includestdio.h#define NUM 200int inBufNUM,outBufNUM,count=0;void readData();void writeData();void findValue()void main()int i:readData();findValue();writeData();printf(“count=%d/n“,count);for(i

3、0;icount;i+)printf(“outBuf%d=%d/n“,i,outBufi);void readData( )FILE*fp;int i;fp=fopen(“IN.DAT“,“r“);for(i=0;iNUM;i+)fscanf(fp,“%d,“,inBufi);fclose(fp);void writeData()FILE*fp;int i:fp=fopen(“OUT.DAT“,“w“):fprintf(fp,“count=%d/n“,count);for(i=0;icount;i+)fprintf(fp,“%d,/n“,outBufi);fclose(fp);(分数:100

4、00)_三级数据库技术机试-212 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.文件 IN.DAT 中存有 200 个 4 位整型数,函数 ReadData()负责将 IN.DAT 中的数读到数组 inBuf中。请编写函数 findValue(),其功能是:求出千位数字上的值加十位数字上的值等于百位数字上的值减上个位数字上的值,并且此 4 位数是偶数的数,用 count 记录下符合条件的数的个数并按照从小到大的顺序存入数组 outBuf中。函数 WriteData()负责将 outBuf中的数输出到文件 OUT.DAT 中并且在屏幕上显

5、示出来。注意:部分源程序已给出。程序中已定义数组:inBuf200,outBuf200,已定义变量:count。请勿改动主函数 main()、读函数 ReadData()和写函数 WriteData()的内容。试题程序:#includestdio.h#define NUM 200int inBufNUM,outBufNUM,count=0;void readData();void writeData();void findValue()void main()int i:readData();findValue();writeData();printf(“count=%d/n“,count);f

6、or(i=0;icount;i+)printf(“outBuf%d=%d/n“,i,outBufi);void readData( )FILE*fp;int i;fp=fopen(“IN.DAT“,“r“);for(i=0;iNUM;i+)fscanf(fp,“%d,“,inBufi);fclose(fp);void writeData()FILE*fp;int i:fp=fopen(“OUT.DAT“,“w“):fprintf(fp,“count=%d/n“,count);for(i=0;icount;i+)fprintf(fp,“%d,/n“,outBufi);fclose(fp);(分数

7、100.00)_正确答案:(void findValue()int i,j,k,d4,temp;for(i=0;iNUM;i+)for(j=0;j4;j+)temp=inBufi; /将要进行分解的数据存入 temp 中for(k=0;kj;k+)temp=temp/10;/求第 j 位的值时d3-i=temp%10; /先将 temp 除以 10 的 i 次方,再对其求余即可if(d0+d2=d1-d3d3%2=0)outBurcount=inBufi;count+:for(i=0;icount-1;i+) /以下是将数据进行从小到大排序的程序for(j=i+1;jcount;j+)if(

8、outBufioutBufj) /如果第 i 位比它后面的数大,则将两者进行交换,也即将更小的值放到第i 位temp=outBufi;outBufi=outBurj;outBufj=temp;)解析:解析 本题主要考查数位分解及排序。数位分解就是将 n 位数上各个位上的数值单独分离出来。解决此问题的方法是:将 n 位数对 10 求余可以将个位上的数值分离出来。将这个 n 位数除以 10 以后得到一个 n-1 位数,则此时 n 位数原来的十位就变成了 n-1 位数的个位,再将此 n-1 位数对 10 求余便可得到原 n 位数的十位。依次类推,按照同样的方法便可将 n 位数各个位上的数值分离出来。程序步骤:将数值送入 temp 中;由 temp%10 得到个位数,(temp/10)%10 得到十位数如此可得到各位上的数值;按照题目所给的条件选出数据;对选出的数据进行排序,排序的思想是(以从小到大为例),将当前数据与其后的各个数据相比较,如果当前的数据比其后的数据大,则将两数据进行交换,从而使得前面的数据小于后面的数据,达到从小到大排序的目的。

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