1、三级数据库技术机试-250 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN87.DAT中存有 300个 4位数,并已调用函数 readDat()把这些数存入数组 a中,请编制一函数 isValue(),其功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数 cnt,再求出所有满足此条件的 4位数平均值 pjz1,以及所有不满足此条件的 4位数的平均值pjz2,最后调用函数 writeDat()把结果 cnt,pjz1,pjz2,输出到 out87.dat文件中。例如:6712,6+2=7+1,则该数
2、满足条件,计算平均值 pjz1,且个数 cnt=cnt+1。8129,8+91+2,则该数不满足条件,计算平均值 pjz2。注意:部分源程序已给出。程序中已定义数组:a300,b300,已定义变量:cnt,pjz1,pjz2。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio .hint a300, cnt=0;double pjz1=0.0,pjz2=0.0;void jsValue()main ( )int i;readDat ( );jsValue();writeDat ( );printf ( “cnt=%
3、d/n满足条件的平均值 pjz1=%7.21fkn不满足条件的平均值 pjz2=%7.21f/n“,cnt,pjz1,pjz2);readDat ( )FILE *fp;int i;fp=fopen( “in87.dat“,“r“);for (i=0; i300; i+)fscanf(fp,“%d,“,fclose(fp);writeDat ( )FILE *fp;int i;fP=fopen(“out87.dat“,“w“);fprintf(fP,“%dkn%7.21f/n%7.21f/n“,cnt ,pjz1,pjz2);fclose(fp);(分数:100.00)_三级数据库技术机试-2
4、50 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.已知数据文件 IN87.DAT中存有 300个 4位数,并已调用函数 readDat()把这些数存入数组 a中,请编制一函数 isValue(),其功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数 cnt,再求出所有满足此条件的 4位数平均值 pjz1,以及所有不满足此条件的 4位数的平均值pjz2,最后调用函数 writeDat()把结果 cnt,pjz1,pjz2,输出到 out87.dat文件中。例如:6712,6+2=7+1,则该数满足条件,计算平均值 p
5、jz1,且个数 cnt=cnt+1。8129,8+91+2,则该数不满足条件,计算平均值 pjz2。注意:部分源程序已给出。程序中已定义数组:a300,b300,已定义变量:cnt,pjz1,pjz2。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio .hint a300, cnt=0;double pjz1=0.0,pjz2=0.0;void jsValue()main ( )int i;readDat ( );jsValue();writeDat ( );printf ( “cnt=%d/n满足条件的平均值
6、pjz1=%7.21fkn不满足条件的平均值 pjz2=%7.21f/n“,cnt,pjz1,pjz2);readDat ( )FILE *fp;int i;fp=fopen( “in87.dat“,“r“);for (i=0; i300; i+)fscanf(fp,“%d,“,fclose(fp);writeDat ( )FILE *fp;int i;fP=fopen(“out87.dat“,“w“);fprintf(fP,“%dkn%7.21f/n%7.21f/n“,cnt ,pjz1,pjz2);fclose(fp);(分数:100.00)_正确答案:(void j sValue ( )
7、(int i, thou, hun, ten, data, n=0;for (i=0; i300; i+)thou=a i/1000; /*求四位数的千位数字*/hun=a i %1000/100; /*求四位数的百位数字*/ten=a i %100/10; /*求四位数的十位数字*/data=a i %10; /*求四位数的个位数字*/if thou+data=hun+ten) /*如果千位数加个位数等于百位数加十位数*/cnt+; /* 则统计满足条件的数的个数*/pjz1+=ai; /*将满足条件的数求和*/elsen+; /*否则统计不满足条件的数的个数*/pjz2+=ai; /*将不满足条件的数求和*/ pjz1/=cnt; /*求满足条件的数的平均值*/pjz2/=n; /*求不满足条件的数的平均值*/)解析:解析 本题考查的知识点如下:(1)运算符“%”及“/”的使用。(2)循环结构及选择结构的使用。在本题中,首先要将一个 4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%”(取余)和“/”(整除),拆分方法略。然后判断符合千位数+个位数=百位数+十位数的数的个数。依次求得符合各种条件的数的和及其平均值。