1、三级网络技术机试-213 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN.DAT 中存有 200 个四位数,并已调用读函数 readDat()把这些数存入数组 a 中,请考生编制一个函数 jsVal(),其功能是:把千位数字和十位数字重新组成一个新的含有两位数字的数(新数的十位数字是原四位数的千位数字,新数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的含有两位数字的数(新数的十位数字是原四位数的个位数字,新数的个位数字是原四位数的百位数字),如果两个新组成的数均是素数且新数的十位数字均不为 0,
2、则将满足此条件的四位数按从大到小的顺序存人数组 b 中,并要计算满足上述条件的四位数的个数 cnt。最后:main()函数调用写函数 writeDat()把结果 cnt 以及数组 b 中符合条件的四位数输出到 OUT.DAT 文件中。注意:部分源程序存在文件 PROG1.C 文件中。程序中已定义数组:a200,b200,已定义变量:cnt。请勿改动数据文件 IN.DAT 中的任何数据、主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序#indude #define MAX 200int aMAX,bMAX,cnt=0;void writeDat();
3、int isprime(int m)int i;for(i=2;im/2;i+)if(m%i=0) return 0;return 1;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“in.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;j+) printf(“%d“,bi);printf(“/n”);writeDat();void wri
4、teDat()FILE *fp;int i;fp=fopen(“out.dat”,“w”);fprintf(fp,“%d/n”,cnt);for(i=0;icnt;i+)fprintf(fp,“%d/n“,bi);fclose(fp);(分数:100.00)_三级网络技术机试-213 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN.DAT 中存有 200 个四位数,并已调用读函数 readDat()把这些数存入数组 a 中,请考生编制一个函数 jsVal(),其功能是:把千位数字和十位数字重新组成一个新的含有两位数字的数(
5、新数的十位数字是原四位数的千位数字,新数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的含有两位数字的数(新数的十位数字是原四位数的个位数字,新数的个位数字是原四位数的百位数字),如果两个新组成的数均是素数且新数的十位数字均不为 0,则将满足此条件的四位数按从大到小的顺序存人数组 b 中,并要计算满足上述条件的四位数的个数 cnt。最后:main()函数调用写函数 writeDat()把结果 cnt 以及数组 b 中符合条件的四位数输出到 OUT.DAT 文件中。注意:部分源程序存在文件 PROG1.C 文件中。程序中已定义数组:a200,b200,已定义变量:cnt。
6、请勿改动数据文件 IN.DAT 中的任何数据、主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序#indude #define MAX 200int aMAX,bMAX,cnt=0;void writeDat();int isprime(int m)int i;for(i=2;im/2;i+)if(m%i=0) return 0;return 1;void jsVal()void readDat()int i;FILE *fp;fp=fopen(“in.dat“, “r“);for(i=0;iMAX;i+)fscanf(fp,“%d”fclose(f
7、p);void main()int i;readDat();jsVal();printf(“满足条件的数=%d/n“,cnt);for(i=0;icnt;j+) printf(“%d“,bi);printf(“/n”);writeDat();void writeDat()FILE *fp;int i;fp=fopen(“out.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
8、,a2,a3,a4;int ab,cd;int temp;for(i=0;iMAX;i+)a1=ai%10; /*数位分解*/a2=ai%100/10;a3=ai%1000/100;a4=ai/1000;ab=a4*10+a2; /*数位重组*/cd=a1*10+a3;if(isprime(ab)for(i=0;icnt-1;i+) /*选择法排序*/for(1=i+1;jcnt;j+)if(bibj)temp=bi;bi=bi;bj=temp;)解析:解析 本题要求先将已知数按十进制位拆分并重新成两个两位数后,先按照一定的判断条件筛选统计,再按大小进行排序。依据题意,应依次从数组 a 中取出每一个四位数,按十进制位拆分并重组后,根据题目中给出的判断条件(两个新组成的数均是素数且新数的十位数字均不为 0,即 isprime(ab)&isprime(cd)&a4!=0&a1!=0)筛选后,将符合条件的四位数存入数组 b 中,同时计数器变量 cnt 加 1,最后将数组 b 中的四位数用选择法进行排序。注意:本题源代码中给出了求素数的 isprime()函数,可以直接调用该函数判断数是否是素数。