1、三级信息管理技术机试-177 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN22.DAT中存有 200个 4位数,并已调用读函数 readDat()把这些数存入数组 a中,请编制一函数 jsVal(),其功能是:如果一个 4位数的千位数字加十位数字恰好等于百位数字加上个位数字,并且此 4位数是偶数,则统计出满足此条件的数的个数 cnt并把这些 4位数按从小到大的顺序存入数组 b中,最后调用写函数 writeDat()把结果 cnt及数组 b中符合条件的 4位数输出到 0UT22.DAT文件中。注意:部分源程序已给出。程序
2、中已定义数组:a200,b200,已定义变量:cnt。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序#includestdio.h#define MAX 200int aMAX,bMAX,cnt=0;void writeDat();void jsVal()void readDat()int i;FILE*fp;fp=fopen(“IN22.DAT“,“r“);for(i=0;iMAX;i+)fscanf(fp,“%d“,fclose(fp);voidmain()int i;readDat();jsVal();printf(“满足条件的数=
3、%d/n“,cnt);for(i=0;icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();void writeDat()FILE*fP;int i;fP=fopen(“OUT22.DAT“,“w“);fprintf(fp,“%d/n“,cnt);for(i=0;icnt;i+)fprintf(fp,“% d/n“,bi);fclose(fp);(分数:100.00)_三级信息管理技术机试-177 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN22.DAT中存有 200个 4位数,
4、并已调用读函数 readDat()把这些数存入数组 a中,请编制一函数 jsVal(),其功能是:如果一个 4位数的千位数字加十位数字恰好等于百位数字加上个位数字,并且此 4位数是偶数,则统计出满足此条件的数的个数 cnt并把这些 4位数按从小到大的顺序存入数组 b中,最后调用写函数 writeDat()把结果 cnt及数组 b中符合条件的 4位数输出到 0UT22.DAT文件中。注意:部分源程序已给出。程序中已定义数组:a200,b200,已定义变量:cnt。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序#includestdio.h#
5、define MAX 200int aMAX,bMAX,cnt=0;void writeDat();void jsVal()void readDat()int i;FILE*fp;fp=fopen(“IN22.DAT“,“r“);for(i=0;iMAX;i+)fscanf(fp,“%d“,fclose(fp);voidmain()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0;icnt;i+)printf(“%d“,bi);printf(“/n“);writeDat();void writeDat()FILE*fP;int
6、i;fP=fopen(“OUT22.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; /*定义循环控制变量*/int a1,a2,a3,a4; /*定义变量保存 4位数的每位数字*/int temp; /*定义数据交换时的暂存变量*/for(i=0;i200;i+) /*逐个取每一个 4位数*/a4=ai/1000; /*求 4位数的千位数字*/a3=ai%1000/100; /*求 4位数的百位数字*
7、/a2=ai%100/10; /*求 4位数的十位数字*/al=ai%10; /*求 4位数的个位数字*/if(a4+a2=a3+a1 /*则将满足条件的数存入数组 b中*/cnt+; /*统计满足条件的数的个数*/for(i=0;icnt-1;i+) /*将数组 b中的数按从小到大的顺序排列*/for(j=i+1;jcnt;j+)if(bibj)temp=bi;bi=bj;bj=temp;)解析:解析 根据题意可知,函数 jsVal()要实现两个功能:一是找出满足条件的那些数,并存放在数组 b中;二是对数组 b中的数进行从小到大的排序。首先来找出满足条件的数,其关键在于判断每个数是否能够满足“千位数字加十位数字等于百位数字加上个位数字,并且该数是偶数”的条件。其次,将满足条件的数存入数组 b中,并用变量 cnt来统计数组 b中元素的个数。最后,将所有满足条件的数取出后利用选择法进行排序,即将当前元素依次同它后面的元素进行比较,发现有小于该数的数,就进行交换。