1、三级数据库技术机试-284 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN53DAT 中存有 200 个 4 位数,并已调用读函数 readDat()把这些数存入数组 a 中,请编制一函数 jsVal(),其功能是;依次从数组 a 中取出一个 4 位数,如果该 4 位数连续大于该 4 位数以前的 5 个数且该数是偶数,则统计出满足此条件的数个数 cnt 并把这些 4 位数按从大到小的顺序存入数组 b中,最后调用写函数 wilteDat()把结果 cnt 及数组 b 中符合条件的 4 位数输出到文件 OUT53DAT 中。
2、注意:部分源程序已给出。程序中已定义数组:a200,b200,已定义变量:Cnto 请勿改动主函数 main()、读函数 readDat()和写函数 wiltedat()的内容。 试题程序:#include#define MAX 200int aMAX,bMAXl,cnt;0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“in53.dat“,“r“);for(i=0;iMAX;i+)fscanf(fp,“%d“,fclose(fp);void main()int i;readDat();jsVal();printf (“满足条件的数=%d
3、/n“, cnt);for(i=0;icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();writeDat()FILE *fp;int i;fp=fopen(“out53.dat“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);(分数:100.00)_三级数据库技术机试-284 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN53DAT 中存有 200 个 4 位数,并已调用读
4、函数 readDat()把这些数存入数组 a 中,请编制一函数 jsVal(),其功能是;依次从数组 a 中取出一个 4 位数,如果该 4 位数连续大于该 4 位数以前的 5 个数且该数是偶数,则统计出满足此条件的数个数 cnt 并把这些 4 位数按从大到小的顺序存入数组 b中,最后调用写函数 wilteDat()把结果 cnt 及数组 b 中符合条件的 4 位数输出到文件 OUT53DAT 中。注意:部分源程序已给出。程序中已定义数组:a200,b200,已定义变量:Cnto 请勿改动主函数 main()、读函数 readDat()和写函数 wiltedat()的内容。 试题程序:#incl
5、ude#define MAX 200int aMAX,bMAXl,cnt;0;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“in53.dat“,“r“);for(i=0;iMAX;i+)fscanf(fp,“%d“,fclose(fp);void main()int i;readDat();jsVal();printf (“满足条件的数=%d/n“, cnt);for(i=0;icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();writeDat()FILE *fp;int i;fp=fopen(
6、“out53.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,j,flag;for(i=5;iMAX;i+)for(j=i-5;ji;j+)if(aiaj) /*如果该 4 位数连续大于它以前的 5 个数*/flag=1; /*则置 flag 为 1*/else flag=0; /*否则置 flag 为 0*/if(ai%2!=0) /*如果该四位数为奇数*/flag=0; /*则置 flag 为 0*/i
7、f(flag=0)break; /*如果 flag 为 0,则退出循环*/if(flag=1) bcnt=ai; /*把满足条件的数存入数组 b 中*/cnt+; /*统计满足条件的数的个数*/for(i=0;icnt-1;i+) /*将数组 b 中的数按从大到小的顺序排列*/for(j=i+1;jont;j+)if(bibj) flag=bi;bi=bj;bj=flag;)解析:解析 本题考查的知识点如下;(1)使用循环对数组的元素进行比较和排序。(2)强行退出循环结构。在本题中,数组 b 中的数据要满足的条件有两个。在这里,不再使用判断结构中条件的布尔运算,而采用一种新的方法设置标志变量 flag。当数据不满足某一条件时,如数据不是偶数,将 flag 设置为 0;当 flag 等于 0 时,可直接退出本层循环结构,进入外层的循环中。否则,根据题意要求,将数据存入数组 b 中。对数组 b 中的数据排序,使用“选择排序法”。