计算标准差的 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

更新时间:2021 年 3 月 25 日

6K+ 次浏览

开启你的职业生涯

完成课程并获得认证

开始
广告