簡體   English   中英

使用Linq計算C#中的平均評分

[英]Using Linq to calculate rating average in C#

我有一個數組等級,其中等級[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).

有多種方法可以執行此操作,例如,使用“ Select在計算中包含每個等級的索引:

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

如果等級本身是整數,則需要將上述內容的一側進行double以使結果不被整數除。

只需保持一個連續的總和和項目的連續計數。 對於列表中的每個項目,將其添加到總計數,然后根據該值的計數乘以值本身,將其添加到運行總和:

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();

ratings.Sum() / ratings.Count()應該可以。 如果沒有,您需要比“不做我想做的事情”更為詳細。

並且,如果其他所有方法均失敗,請嘗試:

ratings.Average();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM