所以我计算了文件中读取的双值的平均值和标准偏差。
我的文件数据每行有1个数字: 我在该文件中的数据如下
1
2
3
4
5
6
7
8
9
10
我的代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main(){
FILE *inputfile;
char name[100];
printf("Enter the file you want to use to calculate standard deviation:\n ");
gets(name);
inputfile = fopen(name, "r");
if (inputfile == NULL)
{
printf("Failed to open text file.\n");
exit(1);
}
double i;
double j=1;
double average;
double stdish=0;
double stdreal=0;
double x=0;
double sum=0;
double stdfinal;
while(fscanf(inputfile, "%lf", &i) != EOF){
x=x+1;
sum = sum + i;
j =pow(i,2);
stdreal +=j;
}
average = sum/x;
stdish = (stdreal/x)-(pow(average,2));
stdfinal = sqrt(stdish);
printf("The average is %.4lf\n", average);
printf("The standard deviation is %.4lf\n", stdfinal);
return 0;
}
我的标准差是不正确的,我不知道为什么。 在我的程序中,我使用fopen从输入文件中获取文本。 另外,我试图让它从终端而不是实际程序本身输入文本文件。怎么做?
答案 0 :(得分:0)
首先,您需要找出平均值(平均值),然后遍历循环以找出方差。 SQRT(方差)将为您提供标准偏差。
double CalculateMean()
{
double sum = 0;
for(int i = 0; i < max; i++)
sum += value[i];
return (sum / max);
}
double CalculateVariane()
{
mean = CalculateMean();
double temp = 0;
for(int i = 0; i < max; i++)
{
temp += (value[i] - mean) * (value[i] - mean) ;
}
return temp / max;
}
参考:http://www.softwareandfinance.com/CPP/MeanVarianceStdDevi.html
答案 1 :(得分:0)
将main
声明为int main(int argc, char *argv[])
或int main(int argc, char **argv)
。他们的意思是一样的。在此版本中,argc
是命令行参数的数量(+1,因为程序名称是参数0)。 argv
是一个char *
的数组,每个数组都是一个命令行参数。
您可以这样做:
int main(int argc, char *argv[])
{
FILE *inputfile;
char name[100];
if(argc == 1) {
printf("Enter the file you want to use to calculate standard deviation:\n ");
gets(name);
} else {
strcpy(name, argv[1]);
}
inputfile = fopen(name, "r");
if (inputfile == NULL)
{
printf("Failed to open text file.\n");
exit(1);
}
double i;
double j=1;
double average;
double stdish=0;
double stdreal=0;
double x=0;
double sum=0;
double stdfinal;
while(fscanf(inputfile, "%lf", &i) != EOF){
x=x+1;
sum = sum + i;
j =pow(i,2);
stdreal +=j;
}
average = sum/x;
stdish = (stdreal/x)-(pow(average,2));
stdfinal = sqrt(stdish);
printf("The average is %.4lf\n", average);
printf("The standard deviation is %.4lf\n", stdfinal);
return 0;
}