1、三级信息管理技术机试-319 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN23.DAT 中存有 200 个 4 位数,并已调用读函数 readDat()把这些数存入数组 a 中。请编制函数 jsVal(),其功能是:依次从数组 a 中取出一个 4 位数,如果 4 位数连续大于该 4 位数以前的 5个数且该数是奇数,该数必须能被 7 整除,则统计出满足此条件的数的个数 cnt,并把这些 4 位数按从大到小的顺序存入数组 b 中,最后调用写函数 writeDat()把结果 cnt 及数组 b 中符合条件的 4 位数输出到O
2、UT23.DAT 文件中。注意:部分源程序已给出。程序中已定义数组:a200,b200,已定义变量:cnt。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#include stdio.h#define MAX 200int aMAX, bMAX, cnt = 0;void jsVal()void readDat ( )int i;FILE *fp;fp = fopen(“IN23.DAT“,“r“);for(i=0; iMAX; i+)fscanf(fp, “%d“, fclose (fp);main ( )int i;readDat
3、( );jsVal ( );printf(“满足条件的数=%d/n“, cnt);for(i=0; icnt; i+)print f ( “%d“, bi);print f ( “/n“ );writeDat ();writeDat ()FILE *fp;int i;fp = fopen(“OUT23.DAT“, “w“);fprintf(fp, “%d/n“, cnt);for(i=0; icnt; i+)fprintf(fp, “%d/n“, bi );fclose (fp);(分数:100.00)_三级信息管理技术机试-319 答案解析(总分:100.00,做题时间:90 分钟)一、上机
4、题(总题数:1,分数:100.00)1.已知数据文件 IN23.DAT 中存有 200 个 4 位数,并已调用读函数 readDat()把这些数存入数组 a 中。请编制函数 jsVal(),其功能是:依次从数组 a 中取出一个 4 位数,如果 4 位数连续大于该 4 位数以前的 5个数且该数是奇数,该数必须能被 7 整除,则统计出满足此条件的数的个数 cnt,并把这些 4 位数按从大到小的顺序存入数组 b 中,最后调用写函数 writeDat()把结果 cnt 及数组 b 中符合条件的 4 位数输出到OUT23.DAT 文件中。注意:部分源程序已给出。程序中已定义数组:a200,b200,已定
5、义变量:cnt。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#include stdio.h#define MAX 200int aMAX, bMAX, cnt = 0;void jsVal()void readDat ( )int i;FILE *fp;fp = fopen(“IN23.DAT“,“r“);for(i=0; iMAX; i+)fscanf(fp, “%d“, fclose (fp);main ( )int i;readDat ( );jsVal ( );printf(“满足条件的数=%d/n“, cnt);for(i
6、=0; icnt; i+)print f ( “%d“, bi);print f ( “/n“ );writeDat ();writeDat ()FILE *fp;int i;fp = fopen(“OUT23.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=0;for(i=5;iMAX-5;i+) /*如果 4 位数连续大于该数以前的 5 个数,则置 flag 为 1,否
7、则取下一个数*/for(j=i-5; ji; j+)if(aiaj)flag=1;elseflag0; break; if(flag=1cnt+;for (i=0; icnt-1; i+) /*将数组 b 中的数按从大到小的顺序排列*/for (j=i+1; jcnt; j+)if (bi bj )flag=b i;bi=bj;b j =flag;)解析:解析 根据题意可知,要编制函数的功能有两部分:一是找出满足条件的 4 位数,二是对找出的数进行从大到小排序。首先利用一个 for 循环来依次从数组中取得 4 位数,接着拿当前得到的 4 位数与该数前面的连续的 5 个数依次进行比较。如果该数比它前面的 5 个数都大,则给标志变量 flag 赋值 1,接着对 flag 进行判断,如果不为 1,则该数肯定不符合条件,直接去取下一个数。若 flag 值为 1,再来判断该数是否是奇数,如果恰好该数又能被 7 整除则把该数添加到数组 b 中。这样就可以依次取出符合条件的数。然后利用选择法对数组 b 中的元素进行从大到小的排序。