c# - 如何在 C# 中对两个字典中的值求和?

标签 c# .net linq dictionary sum

我有两个结构相同的字典:

Dictionary<string, int> foo = new Dictionary<string, int>() 
{
    {"Table", 5 },
    {"Chair", 3 },
    {"Couch", 1 }
};

Dictionary<string, int> bar = new Dictionary<string, int>() 
{
    {"Table", 4 },
    {"Chair", 7 },
    {"Couch", 8 }
};

我想将字典的值加在一起,并返回带有键的第三个字典,以及每个键的总值:

Table, 9
Chair, 10
Couch, 9

我当前的解决方案是循环遍历字典并以这种方式将它们拉出,但我知道该解决方案不是最高效或最易读的。但是,我在尝试在 LINQ 中提出解决方案时碰壁了。

最佳答案

以下不是最有效的解决方案(因为它只是将两个字典都视为可枚举),但它会起作用并且非常清楚:

Dictionary<string, int> result = (from e in foo.Concat(bar)
              group e by e.Key into g
              select new { Name = g.Key, Count = g.Sum(kvp => kvp.Value) })
              .ToDictionary(item => item.Name, item => item.Count);

关于c# - 如何在 C# 中对两个字典中的值求和?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2812545/

相关文章:

c# - 使用 protobuf-net.grpc 通过 gRPC 发布/订阅通知服务

c# - 运行一个 C# 程序以在单声道中启动另一个 C# 程序

linq - Entity Framework 3.5 - 如何加载子项

c# - 从 C# 中的字符串数组获取随机值的最快方法?

c# - ASP.NET Core 2.0 应用程序超时时重定向到绝对 URL

c# - C# 程序中的 MissingMethodException

c# - URL 的编码参数

c# - 模拟跨网络文件复制

c# - 传递 Func<TSource, TKey> keySelector 错误

c# - GroupBy 之后的条件选择