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