计算标准差的 C 程序
标准差用来衡量数据与其平均值的偏差。以下是计算标准差的数学公式:
$$s=\sqrt{方差}$$
其中
方差$$=\frac{1}{n}\:\:\displaystyle\sum\limits_{i=1}^n (x_{i}-m)^{2}$$
且
$$m=平均值=\frac{1}{n}\:\displaystyle\sum\limits_{i=1}^n x_{i}$$
算法
参考下方提供的算法根据给定数字计算标准差。
第 1 步 - 读取 n 个项目。
第 2 步 - 计算项目的和和平均值。
第 3 步 - 计算方差。
第 4 步 - 计算标准差。
程序中用于计算标准差的逻辑如下:
for (i = 1 ; i<= n; i++){ deviation = value[i] - mean; sumsqr += deviation * deviation; } variance = sumsqr/(float)n ; stddeviation = sqrt(variance) ;
示例
以下是用 C 语言编写程序,根据给定的数字计算标准差:
#include <math.h> #define MAXSIZE 100 main( ) { int i,n; float value [MAXSIZE], deviation, sum,sumsqr,mean,variance,stddeviation; sum = sumsqr = n = 0 ; printf("Input values: input -1 to end
"); for (i=1; i< MAXSIZE ; i++) { scanf("%f", &value[i]); if (value[i] == -1) break; sum += value[i]; n += 1; } mean = sum/(float)n; for (i = 1 ; i<= n; i++) { deviation = value[i] - mean; sumsqr += deviation * deviation; } variance = sumsqr/(float)n ; stddeviation = sqrt(variance) ; printf("
Number of items : %d
",n); printf("Mean : %f
", mean); printf("Standard deviation : %f
", stddeviation); }
输出
当执行上述程序时,将生成以下输出:
Input values: input -1 to end 2 4 6 8 12 4.5 6.7 0.3 2.4 -1 Number of items: 9 Mean: 5.100000 Standard deviation: 3.348300
广告