★题目93(方差运算题)
此题南开标准解法有误!
请编制函数ReadDat()实现从文件IN.DAT中读取1000个十进制整数到数组xx中;请编制函数Compute(),分别计算出xx中奇数的个数odd,偶数的个数even,平均值aver以及方差totfc的值,最后调用函数WriteDat()把结果输出到OUT.DAT文件中。
计算方差的公式如下:
N 2
totfc=1/N ∑ (xx[i]-aver)
i=1
原始数据文件存放的格式是:每行存放10个数,并用逗号隔开。(每个数均大于0且小于等于2000)
部分源程序存在文件prog1.c中。
请勿改动主函数main()和输出数据函数writeDat()的内容。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 1000
int xx[MAX],odd=0,even=0;
double aver=0.0,totfc=0.0;
void WriteDat(void);
int ReadDat(void)
{
int i;
FILE *fp;
if((fp=fopen("IN.DAT","r"))==NULL) return 1;
/***************编制函数ReadDat()*****************/
for(i=0;i<MAX;i++)
{ fscanf(fp,"%d,",&xx[i]);
if((i+1)%10==0)
fscanf(fp,"\n");
}
/*********************************************/
fclose(fp);
return 0;
}
void Compute(void)
{ int i;
for(i=0;i<MAX;i++)
{ if(xx[i]%2) odd++;
else even++;
aver+=xx[i];
}
aver/=MAX;
for(i=0;i<MAX;i++)
totfc+=(xx[i]-aver)*(xx[i]-aver);
totfc/=MAX;
}
void main()
{
int i;
for(i=0;i<MAX;i++)xx[i]=0;
if(ReadDat()){
printf("数据文件IN.DAT不能打开!\007\n");
return;
}
Compute();
printf("ODD=%d\nOVEN=%d\nAVER=%f\nTOTFC=%f\n",odd,even,aver,totfc);
WriteDat();
}
void WriteDat(void)
{
FILE *fp;
int i;
fp=fopen("OUT.DAT","w");
fprintf(fp,"%d\n%d\n%f\n%f\n",odd,even,aver,totfc);
fclose(fp);
}
考试编辑:admin