1、计算机三级数据库技术-112 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN.DAT中存有 300个 4位数,并已调用函数 readDat()把这些数存入数组 a中,请编写一个函数 jsValue(),其功能是:求出数组 a中个位上的数减去千位上的数减去百位上的数减去十位上的数大于 0的数的个数 cnt,再求出所有满足此条件的 4位数的平均值 pjz1,以及所有不满足此条件的 4位数的平均值 pjz2,最后调用函数 writeDat(),把结果 cnt、pjz1 和 pjz2输出到 OUT.DAT文件。 例如,1239,
2、9-1-2-30,则该数满足条件,计算平均值 pjz1,且个数 cnt=cnt+1。 8129,9-8-1-20,则该数不满足条件,计算平均值 pjz2。” 程序中已定义数组 a300、b300,已定义变量 cnt、pjz1 和 pjz2。请勿改动主函数 main()、读函数readDat()和写函数 writeDat()的内容。 试题程序 #includestdio.h int a300,cnt=0; double pjz1=0.0,pjz2=0.0; void readDat(); void writeDat(); void jsValue() voidmain() readDat();
3、jsValue(); writeDat(); printf(“cnt=%dn满足条件的数的平均值 pjz1 =%7.2lfn不满足条件的数的平均值 pjz2 =%7.2lfn“,cnt,pjz1,pjz2); void readDat() FILE*fp; int i; fp=fopen(“IN.DAT“,“r“); for(i=0;i300;i+) fscanf(fp,“%d,“,ai); fclose(fp); void writeDat() FILE*fp; fp=fopen(“OUT.DAT“,“w“); fprintf(fp.“%dn%7.2lfn%7.2lfn“, cnt,pjz1
4、,pjz2); fclose(fp); (分数:100.00)_计算机三级数据库技术-112 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN.DAT中存有 300个 4位数,并已调用函数 readDat()把这些数存入数组 a中,请编写一个函数 jsValue(),其功能是:求出数组 a中个位上的数减去千位上的数减去百位上的数减去十位上的数大于 0的数的个数 cnt,再求出所有满足此条件的 4位数的平均值 pjz1,以及所有不满足此条件的 4位数的平均值 pjz2,最后调用函数 writeDat(),把结果 cnt、pjz
5、1 和 pjz2输出到 OUT.DAT文件。 例如,1239,9-1-2-30,则该数满足条件,计算平均值 pjz1,且个数 cnt=cnt+1。 8129,9-8-1-20,则该数不满足条件,计算平均值 pjz2。” 程序中已定义数组 a300、b300,已定义变量 cnt、pjz1 和 pjz2。请勿改动主函数 main()、读函数readDat()和写函数 writeDat()的内容。 试题程序 #includestdio.h int a300,cnt=0; double pjz1=0.0,pjz2=0.0; void readDat(); void writeDat(); void j
6、sValue() voidmain() readDat(); jsValue(); writeDat(); printf(“cnt=%dn满足条件的数的平均值 pjz1 =%7.2lfn不满足条件的数的平均值 pjz2 =%7.2lfn“,cnt,pjz1,pjz2); void readDat() FILE*fp; int i; fp=fopen(“IN.DAT“,“r“); for(i=0;i300;i+) fscanf(fp,“%d,“,ai); fclose(fp); void writeDat() FILE*fp; fp=fopen(“OUT.DAT“,“w“); fprintf(f
7、p.“%dn%7.2lfn%7.2lfn“, cnt,pjz1,pjz2); fclose(fp); (分数:100.00)_正确答案:()解析:void jsValue() int i,thou,hun,ten,data,n=0; for(i=0;i300;i+) thou=ai/1000; /*求四位数的千位数字*/ hun=ai%1000/100; /*求四位数的百位数字*/ ten=ai%100/10; /*求四位数的十位数字*/ data=ai%10; /*求四位数的个位数字*/ if(data-thou-hun-ten0) /*如果个位数减千位数减百位数减十位数大于 0*/ cnt
8、+; /*统计满足条件的数的个数*/ pjz1+=ai; /*将满足条件的数求和*/ else n+; /*否则统计不满足条件的数的个数*/ pjz2+=ai; /*将不满足条件的数求和*/ pjz1/=cnt; /*求满足条件的数的平均值*/ pjz2/=n; /*求不满足条件的数的平均值*/ 考点 本题考查对多个整数的筛选以及求平均值。考查的知识点主要包括:多位整数的分解算法,逻辑表达式,平均值的计算方法。 此题属于 4位数的筛选题型,并且涉及统计及平均值问题。解题时,需主要解决 3个问题:问题 1如何取得 4位数的各个数位数字;问题 2如何通过判断条件(本题为个位数减千位数减百位数减十位数的值大于0)对目标进行筛选,再分别统计出满足和不满足条件的数的和以及数目;问题 3分别求出两类数的平均值。解此题的思路为:先求出各位数字的值,根据各位数字的属性判断并统计满足和不满足条件的数的个数及和值,最后用和除以个数得出相应的平均值。与前面类型的题不同的是,在问题 2筛选时,不需要将符合要求的数存入新的数组,只需用条件判断语句分别统计符合条件的数的数目(cnt)及不符合条件的个数(n),以及对应的和值(pjz1、pjz2)。问题 3用和值除以对应个数即可(pjz1/cnt,pjz2/n)。