2

现在这个问题很难。现在这是我的主要清单

List<List<KeyValuePair<string, double>>> dblWordFreqByCluster = new List<List<KeyValuePair<string, double>>>();

所以让我们给出示例列表

(house,40),(home,20),(monitor,40)
(home,10),(work,60),(monitor,30)
(school,70),(home,10),(word,20)

所以每一行都是一个List<KeyValuePair<string, double>>,并且有一个包含所有这些行的最大列表。

我想要做的是选择每个单词的值,将它们相加,然后将整个列表中的单词数除以。所以经过这个修改列表会变成以下

(house,40),(home,40/3),(monitor,70/2)
(home,40/3),(work,60),(monitor,70/2)
(school,70),(home,40/3),(word,20)

这意味着获取每个键的平均值并更新每个键的值。

C# 4.0 WPF

4

1 回答 1

7

使用 Linq 很容易。首先,计算每个键的平均值:

var averages =
    (from list in dblWordFreqByCluster
     from kvp in list
     group kvp by kvp.Key into g
     select new 
     {
         Key = g.Key,
         Avg = g.Average(kvp => kvp.Value)
     }).ToDictionary(x => x.Key, x => x.Avg);

然后更新列表。由于KeyValuePair它是不可变的,因此您需要将这些项目替换为新项目:

foreach (var list in dblWordFreqByCluster)
{
    for (int i = 0; i < list.Count; i++)
    {
        string key = list[i].Key;
        list[i] = new KeyValuePair<string, double>(key, averages[key]);
    }
}
于 2012-04-05T00:49:36.857 回答