三级数据库技术机试-268.doc

上传人:scccc 文档编号:13194206 上传时间:2021-12-18 格式:DOC 页数:2 大小:23.50KB
返回 下载 相关 举报
三级数据库技术机试-268.doc_第1页
第1页 / 共2页
三级数据库技术机试-268.doc_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述

《三级数据库技术机试-268.doc》由会员分享,可在线阅读,更多相关《三级数据库技术机试-268.doc(2页珍藏版)》请在三一文库上搜索。

1、三级数据库技术机试 -268( 总分: 100.00 ,做题时间: 90 分钟 )、上机题( 总题数: 1,分数: 100.00)1.已知数据文件 IN69.DAT 中存有 200个4 位数,并已调用读函数 readDat() 把这些数存入数组 a 中,请编 制一函数 JsVal() ,其功能是:把一个 4 位数的千位数上的值减百位数上的值再减十位数上的值最后减个 位数上的值,如果得出的值大于等于零且此 4 位数是奇数,则统计出满足此条件的数的个数 cnt 并把这些 4 位数存入数组 b 中,然后对数组 b 的 4 位数按从小到大的顺序进行排序,最后调用函数 writeDat() 把结 果 c

2、nt 及数组 b 中的符合条件的 4 位数输出到 out69.dat 文件中。注意:部分源程序已给出。程序中己定义数组: a200 ,b200 ,已定义变量: cnt 。请勿改动主函数 main() 、读函数 readDat() 和写函数 writeDat() 的内容。 试题程序:#include < stdio.h >#define MAX 200int a MAX, b MAX, cnt=0;void jsVal()void readDat()int i;FILE *fp;fp=fopen ("IN69. DAT" , "r");for(

3、i=0; i < MAX; i+)fscanf(fp, "%d",&ai);fclose(fp);void main( )int i;readDat ( );jsVal ();printf (" 满足条件的数 =%d/n", cnt);for (i=0; i < cnt; i+)printf ("%d",bi);printf ("/n");writeDat ( );writeDat ( )FILE *fp;int i;fp=fopen ( "out69.dat","

4、w")fprintf (fp, "%din", cnt);for (i=0; i < ent; i+) fprintf (fp, "%d/n" ,b i); felose(fp);分数: 100.00 ) 正确答案: (void jsVal()int i,thou ,hun,ten ,data ,j ;for(i=0 ;i < MAX;i+)thou=ai/1000; /* 求四位数的千位数字 */hun=ai%1000/100 ; /* 求四位数的百位数字 */ ten=ai%100/10 ; /* 求四位数的十位数字 */ da

5、ta=ai%10 ; /* 求四位数的个位数字 */if(thou-hun-ten-data > 0) &&ai%2=1)/* 如果千位数减百位数再减十位数最后减个位数得出的值大于等于零且此 4 位数是奇数 */bent=ai ; /* 则将该数存入数组 b 中 */ent+ ; /* 统计满足条件的数的个数 */for(i=0 ;i < ent-1 ;i+) /* 对数组 b 的 4 位数按从小到大的顺序进行排序 */for(j=i+1 ;j < ent ;j+)if(bi > bj)data=bi ;bi=bj;bj=data ;)解析: 解析 本题

6、考查的知识点如下:(1) “%”与“ / ”的使用。(2) 循环结构与判断结构的使用。(3) 数据的排序。本题中,首先借助“ %”与“ / ”将 4 位数各位上的数拆成独立的数字: 将 1 个 4 位数整除 1000 则可得到其 千位上的数字,除以 1000 取余再整除 100 则可得百位上的数字,除以 100 取余再整除 10 则可得十位上的 数字,除以 10 取余则得个位上的数字。 1 个数除以 2 取余所得的数等于 1 ,则此数是奇数。利用循环结构 实现对 200 个数据的判断。题中要求将符合条件的 4 位数按从小到大的顺序存入数组 b 中,我们可以先将 符合条件的4位数存入数组b,然后对b中的数进行排序。排序使用“选择排序法”。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1