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