66、请编制函数READDAT()实现从文件IN.DAT中读取1000个十进制整数到数组XX中;再
编制函数COMPUTE()分别计算出XX中偶数的个数EVEN,奇数的平均值`AVE1,偶数的平均值
AVE2以所有偶数的方差TOTFC的值,最后调用函数WRITEDAT()把结果输出到OUT.DAT文件中
.
计算方差的公式如下:
设N为偶数的个数,XX[I]为偶数,AVE2为偶数的平均值.
原始数据文件存放的格式是:每行存放10个数,并用逗号隔开(每个数均大于0且小于等于
2000).
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define MAX 1000

int xx[MAX],odd=0,even=0;
double ave1=0.0,ave2=0.0,totfc=0.0;

void WriteDat(void) ;

int ReadDat(void)
{
FILE *fp ;

if((fp=fopen("in.dat","r"))==NULL) return 1;

fclose(fp) ;
return 0 ;
}

void Compute(void)
{

}

void main()
{
int i ;
for(i=0;i<MAX;i++)
xx[i]=0;
if(ReadDat())
{printf("Can't open the data file in.dat!\007\n") ;
return;
}
Compute();
printf("EVEN=%d\nAVE1=%lf\nAVE2=%lf\nTOTFC=%lf\n", even,ave1,ave
2,totfc);
WriteDat();
}

void WriteDat(void)
{
FILE *fp;
int i;

fp=fopen("out.dat", "w") ;
fprintf(fp, "%d\n%lf\n%lf\n%lf\n",even,ave1,ave2,totfc);
fclose(fp) ;
}

/* 注:
int ReadDat(void)
{
FILE *fp ;
int i;

if((fp=fopen("in.dat","r"))==NULL) return 1;
for(i=0;i<MAX;i++)
{fscanf(fp,"%d,",&xx[i]);
if(feof(fp)) break;
}
fclose(fp) ;
return 0 ;
}

void Compute(void)
{
int i,yy[1000];
for(i=0;i<MAX;i++)
if(xx[i]%2)
{odd++;
ave1+=xx[i];
}
else
{even++;
ave2+=xx[i];
yy[even-1]=xx[i];
}
ave1/=odd;
ave2/=even;
for(i=0;i<even;i++)
totfc+=(yy[i]-ave2)*(yy[i]-ave2)/even;
}

返回南开百题目录

www.163164.cn 联系QQ:3149886