1、三级数据库技术机试-251 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN86.DAT中存有 200个 4位数,并已调用读函数 readDat()把这些数存入数组 a中,请编制一函数 JsVal(),其功能是;把千位数字和十位数字重新组合成一个新的十位数 ab(新十位数的十位数字是原 4位数的千位数字,新十位数的个位数字是原 4位数的十位数字;),以及把个位数字和百位数字组成另一个新的十位数 cd(新十位数的十位数字是原 4位数的个位数字,新十位数的个位数字是原 4位数的百位数字),如果新组成的两个十位数 abcd,ab
2、 必须是偶数且能被 5整除,cd 必须是奇数,同时两个新十位数字均不为 0,则将满足此条件的 4位数按从大到小的顺序存入数组 b中,并要计算满足上述条件的 4位数的个数 cnt,最后调用写函数 writeDat()把结果 cnt及数组 b中符合条件的 4位数输出到OUT86.DAT文件中。注意:部分源程序已给出。程序中已定义数组:a200,b200,已定义变量:cnt。请勿改动主函数 main()、读函数 readDa()和写函数 writeDat()的内容。试题程序:#inc ludestdio. h#define MAX 200int a MAX, b MAX , cnt=0;void j
3、sVal( )void readDat( )int i;FILE *fp;fp=fopen(“IN86.DAT“,“r“);for (i=0; iMAX; i+)fscanf(fp,“%d“,fclose (fp);main ( )int i;readDat ( );jsVal ( );print f ( “满足条件的数=%d/n“, cnt);for (.i=0; icnt; i+)print f ( “%d“ ,b Iii ;printf ( “/n“ );writeDat ( );writeDat ( )FILE *fp;int i;fp=fopen(“OUT86.DAT“,“w“);f
4、printf(fp,“%d/n“,cnt);for(i=0;icd,ab 必须是偶数且能被 5整除,cd 必须是奇数,同时两个新十位数字均不为 0,则将满足此条件的 4位数按从大到小的顺序存入数组 b中,并要计算满足上述条件的 4位数的个数 cnt,最后调用写函数 writeDat()把结果 cnt及数组 b中符合条件的 4位数输出到OUT86.DAT文件中。注意:部分源程序已给出。程序中已定义数组:a200,b200,已定义变量:cnt。请勿改动主函数 main()、读函数 readDa()和写函数 writeDat()的内容。试题程序:#inc ludestdio. h#define MA
5、X 200int a MAX, b MAX , cnt=0;void jsVal( )void readDat( )int i;FILE *fp;fp=fopen(“IN86.DAT“,“r“);for (i=0; iMAX; i+)fscanf(fp,“%d“,fclose (fp);main ( )int i;readDat ( );jsVal ( );print f ( “满足条件的数=%d/n“, cnt);for (.i=0; icnt; i+)print f ( “%d“ ,b Iii ;printf ( “/n“ );writeDat ( );writeDat ( )FILE *
6、fp;int i;fp=fopen(“OUT86.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp, “%d/n“,bi);fclose(fp);(分数:100.00)_正确答案:(void jsVal( )int i,thou,hun,ten,data,j;int ab,cd;for(i=0;i200;i+)thou=a i/1000; /*求四位数的千位数字*/hun=a i %1000/100; /*求四位数的百位数字*/ten=a i %100/10; /*求四位数的十位数字*/data=a i %10; /*求四位
7、数的个位数字* /ab=thou*10+ten; / *把千位数和十位数重新组合成一个新的十位数 ab* /cd=data*10+hun; / *把个位数和百位数组成另一个新的十位数 cd* /if(ab-cd0) /*将满足条件的数存入数组 b中*/ cnt+; /*统计满足条件的数的个数*/for (i=0; icnt-1; i+ ) /*将数组 b中的数按从大到小的顺序排列*/for (j=i+1; jcnt; j+)if(bibj )data=b i;bi=bj;bj=data;解析 本题考查的知识点如下:(1)将一个 4位整数各位上的数转变成单独的个位数。(2)判断结构中多个条件的布尔运算。(3)循环的使用。(4)数据的排序。 在本题中,首先要将一个 4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%”取余和“/”整除。将 1个 4位数整除 1000则可得到其千位上的数字,将其除以 1000取余再整除 100则可得百位上的数字,除以 100取余再整除 10则可得十位上的数字,除以 10取余则得个位上的数字。若一个数除以 2取余为 0,则这个数是偶数。由题意可知,各个条件必须同时满足,所以各条件之间用“与”运算。先将符合条件的数存入数组 b中,再对 b中的数据进行排序。排序采用“选择排序法”。)解析: