c++求一维数组标准差

  • 2,376 views
  • 阅读模式

最近写的一段c++算法中需要计算标准差,于是就造了个轮子,顺便记录下来...

c++求一维数组标准差

看公式,可以推断出计算标准差分为几步:

  1. 计算平均值u=(x1+x2+...+xn)/n
  2. 计算方差s²=((x1-u)^2 +(x2-u)^2 +...+(xn-u)^2)/n
  3. 计算标准差σ=sqrt(s²)
/**
 * 求平均值
 */
double average(double *x, int len)
{
    double sum = 0;
    for (int i = 0; i < len; i++) // 求和
        sum += x[i];
    return sum/len; // 得到平均值
}
/**
 * 求方差
 */
double variance(double *x, int len)
{
    double average = average(x, len);
    for (int i = 0; i < len; i++) // 求和
        sum += pow(x[i] - average, 2);
    return sum/len; // 得到平均值
}
/**
 * 求标准差
 */
double average(double *x, int len)
{
    double variance = variance(x, len);
    return sqrt(variance); // 得到标准差
}

最后,注意double *x在使用后的释放问题,遵循"谁申请谁释放"(new[]/delete[])原则

if(NULL != x) 
{
    delete[] x;
    x = NULL;
}

weinxin
扫码关注微信公众号--IT老五
微信扫一扫关注公众号,获取更多实用app,订阅地址不定时更新
Liu, Thinkin
  • 本文由 发表于 2018-07-24 16:10:03
  • 转载请务必保留本文链接:https://itlao5.com/514.html
评论  0  访客  0
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定