1、三级数据库技术机试-293 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN44.DAT 中存有 300 个 4 位数,并已调用读函数 readDat()把这些数存入数组 a 中,请编制一函数 JsValue(),其功能是:求出千位数上的数减百位数上数减十位数上的数减个位数上的数大于零的数的个数 cnt,再把所有满足此条件的 4 位数依次存入数组 b 中,然后对数组 b 的 4 位数按从小到大的顺序进行排序,最后调用写函数 writeDat()把数组 b 中的数输出到 OUT44.DAT 文件中。例如:9123,9-1-2
2、-30,则该数满足条件,存入数组 b 中,且个数 cnt=cnt+1。9812,9-8-1-20,则该数不满足条件,忽略。注意:部分源程序已给出。程序中已定义数组:a300,b300,已定义变量:cnt。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio.hint a300,b300,cnt=0;jsValue()main ( )int i;readDat ( )3j sValue ( );writeDat ( );for (i=0; icnt; i+)printf (“b%d =%d/n“, i,bireadDa
3、t ( )FILE *fp;int i;fp= fopen ( “IN44. DAT“ , “r“ );printf (“cnt=%d/n“, cnt);for (i=0; i300; i+)fscanf (fp, “%d, “,writeDat ( )FILE *fp;int i;fp=fopen ( “OUT44. DAT“, “w“ );fprintf (fp, “%d/n“, cnt);for (i=0; icnt; i+)fprintf(fp, “%d/n“,bi);fclose (fp);(分数:100.00)_三级数据库技术机试-293 答案解析(总分:100.00,做题时间:9
4、0 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN44.DAT 中存有 300 个 4 位数,并已调用读函数 readDat()把这些数存入数组 a 中,请编制一函数 JsValue(),其功能是:求出千位数上的数减百位数上数减十位数上的数减个位数上的数大于零的数的个数 cnt,再把所有满足此条件的 4 位数依次存入数组 b 中,然后对数组 b 的 4 位数按从小到大的顺序进行排序,最后调用写函数 writeDat()把数组 b 中的数输出到 OUT44.DAT 文件中。例如:9123,9-1-2-30,则该数满足条件,存入数组 b 中,且个数 cnt=cnt+1。9
5、812,9-8-1-20,则该数不满足条件,忽略。注意:部分源程序已给出。程序中已定义数组:a300,b300,已定义变量:cnt。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio.hint a300,b300,cnt=0;jsValue()main ( )int i;readDat ( )3j sValue ( );writeDat ( );for (i=0; icnt; i+)printf (“b%d =%d/n“, i,bireadDat ( )FILE *fp;int i;fp= fopen ( “IN4
6、4. DAT“ , “r“ );printf (“cnt=%d/n“, cnt);for (i=0; i300; i+)fscanf (fp, “%d, “,writeDat ( )FILE *fp;int i;fp=fopen ( “OUT44. DAT“, “w“ );fprintf (fp, “%d/n“, cnt);for (i=0; icnt; i+)fprintf(fp, “%d/n“,bi);fclose (fp);(分数:100.00)_正确答案:(jsValue ( )int i, thou, hun, ten, data, j;for (i=0; i300; i+)thou
7、=a i/1000; /*求四位数的千位数字*/hun=a i %1000/100; /*求四位数的百位数字*/ten=a i %100/10; /*求四位数的十位数字*/data=a i %10; /“求四位数的个位数字*/if (thou-hun-ten-data0) /*如果千位数减百位数减十位数大于零* /b cnt =a i; /*则把该数存入数组 b 中*/for (i=0; icnt-1; i+) /*对数组 b 的 4 位数按从小到大的顺序进行排序*/for (j=i+1; jcnt; j+)if (bibj)data=bi;bi=bj;bj=data;)解析:解析 本题考查的知识点如下:(1) 运算符“%“及“/“的使用。(2) 循环结构及选择结构的使用。在本题中,首先要将一个 4 位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%” (取余)和“/” (整除)。将一个 4 位数整除 1000 则可得到其千位上的数字,除以 1000 取余再整除 100 则可得百位上的数字,除以 100 取余再整除 10 则可得十位上的数字,除以 10 取余则得个位上的数字。然后按照题意要求将各位依次相减进行判断。最后的排序采用“选择排序法”。