我想计算浮点数组的平均值。我需要使用索引,因为这是在二进制搜索中,所以顶部和底部会移动。 (大图我们试图优化半范围估计,所以我们不必每次都重新创建阵列)。c#float []平均丢失精度
反正我写了一个自定义的平均循环,我得到比C#的平均精度2位以下()方法
float test = input.Average();
int count = (top - bottom) + 1;//number of elements in this iteration
int pos = bottom;
float average = 0f;//working average
while (pos <= top)
{
average += input[pos];
pos++;
}
average = average/count;
例如:
0.0371166766 - c# 0.03711666 - my loop 125090.148 - c# 125090.281 - my loop
尝试存储'average'作为双,并在年底转换为'float'。 – Servy 2013-02-12 18:32:56
我也会重命名你的累加器'sum',并最终使用一个新的变量'average'。 – CodesInChaos 2013-02-12 18:36:16
浮点数字几乎总是只是一个近似值。如果您的平均计算与c#Average()不同,您将得到不同的结果。看看这个:http://stackoverflow.com/questions/4664662/understanding-floatingpoint-problems – Jobo 2013-02-12 18:43:16