1、计算机三级数据库技术-150 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知在文件 IN.DAT中存有若干个(个数200)4 位正整数,函数 ReadDat()的功能是读取这若干个正整数并存入数组 xx中。请编写函数 calValue(),其功能是:(1)求出这文件中正整数的个数 totNum;(2)求出各位数字之和是偶数的数的个数 totCnt,以及满足此条件的数的算术平均值 totPjz;(3)调用函数WriteDat(),把结果输出到文件 OUT.DAT中。 注意:请勿改动主函数 main()、读函数 ReadDat()和写函数
2、 WriteDat()的内容。 【试题程序】 #include stdio.h #include stdlib.h #define MAXNUM 200 int xxMAXNUM ; int totNum=0; / 文件 IN.DAT 中共有多少个正整数 int totCnt =0; /符合条件的正整数的个数 double totPjz =0.0; / 平均值 int ReadDat (void) ; void Writedat (void) ; void CalValue () void main () int i; system (“CLS“) ; for(i=0; iMAXNUM; i+
3、) xxi =0; if (Readdat () printf (“数据文件 IN.DAT 无法打开! 007 n“) ; return; CalValue () ; printf (“文件 IN. DAT 中共有正整数=%d n“, totNum) ; printf (“符合条件的正整数的个数 =%d n“, totCnt) ; printf ( “平均值 =%.2 lfn“, totPjz ) ; Writedat () ; int Readdat (void) FILE * fp; int i =0; if (fp = fopen (“IN.DAT“, “r“) = NULL) retu
4、rn 1 ; while ( ! feof (fp) fscanf (fp, “%d, “, fclose (fp) ; return 0 ; void Writedat (void) FILE * fp; fp = fopen (“OUT. DAT“, “w“) ; fprintf (fp,“%dn%dn%.21fn“,tot- Num, totCnt, totPjz); fclose (fp) ; (分数:100.00)_计算机三级数据库技术-150 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知在文件 IN.DAT中存有若干个(个
5、数200)4 位正整数,函数 ReadDat()的功能是读取这若干个正整数并存入数组 xx中。请编写函数 calValue(),其功能是:(1)求出这文件中正整数的个数 totNum;(2)求出各位数字之和是偶数的数的个数 totCnt,以及满足此条件的数的算术平均值 totPjz;(3)调用函数WriteDat(),把结果输出到文件 OUT.DAT中。 注意:请勿改动主函数 main()、读函数 ReadDat()和写函数 WriteDat()的内容。 【试题程序】 #include stdio.h #include stdlib.h #define MAXNUM 200 int xxMAX
6、NUM ; int totNum=0; / 文件 IN.DAT 中共有多少个正整数 int totCnt =0; /符合条件的正整数的个数 double totPjz =0.0; / 平均值 int ReadDat (void) ; void Writedat (void) ; void CalValue () void main () int i; system (“CLS“) ; for(i=0; iMAXNUM; i+) xxi =0; if (Readdat () printf (“数据文件 IN.DAT 无法打开! 007 n“) ; return; CalValue () ; pr
7、intf (“文件 IN. DAT 中共有正整数=%d n“, totNum) ; printf (“符合条件的正整数的个数 =%d n“, totCnt) ; printf ( “平均值 =%.2 lfn“, totPjz ) ; Writedat () ; int Readdat (void) FILE * fp; int i =0; if (fp = fopen (“IN.DAT“, “r“) = NULL) return 1 ; while ( ! feof (fp) fscanf (fp, “%d, “, fclose (fp) ; return 0 ; void Writedat
8、(void) FILE * fp; fp = fopen (“OUT. DAT“, “w“) ; fprintf (fp,“%dn%dn%.21fn“,tot- Num, totCnt, totPjz); fclose (fp) ; (分数:100.00)_正确答案:()解析:void CalValue() int i; /*定义循环控制变量*/ int a4,a3,a2,a1; /*用来存储正整数的每一位的数字*/ for(i=0;i200;i+) /*逐个取数组中的数进行统计*/ if(xxi0) /*判断是否正整数*/ totNum+; /*统计正整数的个数*/ a4=xxi/1000;
9、 /*求正整数的千位数*/ a3=xxi%1000/100; /*求正整数的百位数*/ a2=xxi%100/10; /*求正整数的十位数*/ a1=xxi%10; /*求正整数的个位数*/ if(a4+a3+a2+a1)%2=0) /*如果各位数字之和是偶数*/ /*计算满足条件的数的个数 totCnt和这些数的总和 sum*/ totCnt+; totPjz+=xxi; totPjz/=totCnt; /*求这些数的算术平均值 totPjz*/ 解析 本题要求先实现 CalValue()函数的功能,再进一步分析,可以归纳出 3个关键点:关键点 1如何取得 4位数的各个数位数字;关键点 2如何通过条件(各个数位数字的和是偶数)来筛选出满足条件的数;关键点 3如何统计满足条件的数的个数,并计算其平均值。 关键点 1通过算术运算取余和除法可以分解得到 4位数各个数位的数字;关键点 2通过 if判断语句和逻辑表达式可以实现;关键点 3先计算满足条件的数的总和,再除以它们的数目即可求得平均值。