使用Linq计算C#中的评分平均值

时间:2014-01-07 17:02:15

标签: c# linq

我有一个数组评级,其中rating [i] = j表示有i的j等级,其中i在1到10之间。我如何使用linq来计算平均等级?

for (int i = 1; i <= 10;i++)
            {
                sum += i * ratings[i];
                nr += ratings[i];
            }
ratingAvg = sum / nr;

如果我使用ratings.Sum() / ratings.Count(),它就不会做我想要的。我需要做ratings.Sum(w => index_of_w_in_the_array * w.value).

之类的事情

3 个答案:

答案 0 :(得分:4)

有几种方法可以做到这一点,例如使用Select来计算每个评级的索引:

var average = ratings.Select((r, n) => r * n).Sum() / ratings.Sum();

如果评级本身是整数,则需要将上述内容的一侧强加到double,这样就不会对结果进行整数除法。

答案 1 :(得分:1)

只需保留一个运行总和和一个项目的运行计数。对于列表中的每个项目,添加到总计数,并根据该值的计数乘以值本身添加到运行总和:

int sum = 0;
int count = 0;
for(int i = 0; i < array.Length; i++)
{
    sum += array[i] * i;
    count += array[i];
}
double average = sum / (double)count;

这是一个LINQ解决方案,看起来很不错,但效率会相当低:

var average = array.SelectMany((n, i) => Enumerable.Repeat(n, i))
    .Average();

答案 2 :(得分:0)

ratings.Sum() / ratings.Count()应该有效。如果没有,你需要比“不做我想要的”更详细。

并且,如果所有其他方法都失败了,请尝试:

ratings.Average();