//实现功能:文件读写,数据处理。
#include<stdio.h>
float a[20][4];//input data
float b[20][2];//output data
int main(void)
{
char i,j;
char pretemp;//
//open input file
FILE *fp = NULL;
fp = fopen("1.txt","r");
if(NULL == fp)
return -1;
//read data from the input file
for(i=0;i<14;i++)
for(j=0;j<4;j++)
{
fscanf(fp,"%f",&a[i][j]);
}
fclose(fp);
fp=NULL;
//data trans1
for(i=0;i<9;i++)
{
pretemp = 100 - 10*(i+1);
for(j=0;j<13;j++)
{
if((a[j][2]>=pretemp) && (a[j+1][2]<pretemp))
break;
}
b[i][0] = (a[j][0]-a[j+1][0])*(pretemp - a[j+1][2]) / (a[j][2] - a[j+1][2]) + a[j+1][0];
printf("%f\r\n",b[i][0]);
}
//data trans2
for(i=0;i<9;i++)
{
pretemp = 100 - 10*(i+1);
for(j=0;j<13;j++)
{
if((a[j][3]>=pretemp) && (a[j+1][3]<pretemp))
break;
}
b[i][1] = (a[j][1]-a[j+1][1])*(pretemp - a[j+1][3]) / (a[j][3] - a[j+1][3]) + a[j+1][1];
printf("%f\r\n",b[i][1]);
}
//write data to file 2.txt
if((fp=fopen("2.txt","w+"))==NULL)
printf("创建失败");
else
printf("创建成功");
for(i=0; i<10; i++)
fprintf(fp,"%f %f\n",b[i][0],b[i][1]);
fclose(fp);
return 0;
}
原始数据:
4.15 4.1499.9967803 100.0022727
4.05 4.03 91.92102273 89.78977273
3.97 3.96 83.11117424 81.01287879
3.9 3.88 73.27367424 71.21287879
3.85 3.83 64.76041667 62.74356061
3.8 3.79 56.84375 54.84772727
3.77 3.76 48.67159091 46.69715909
3.74 3.73 40.1375 38.18579545
3.72 3.71 30.10606061 28.18125
3.68 3.67 19.59469697 17.69829545
3.64 3.64 11.27651515 9.391477273
3.59 3.48 5.114583333 3.323295455
3.48 3.29 3.106060606 1.4
3.16 3.1 0.590909091 1.4