5

我想知道如何计算锯齿状数组中唯一值的数量。

我的域对象包含一个具有空格分隔值的字符串属性。

class MyObject
{
    string MyProperty; //e.g = "v1 v2 v3"
}

给定MyObject的列表,我如何确定唯一值的数量?

以下 linq 代码返回一个由锯齿状数组值组成的数组。一种解决方案是存储一个临时的单个项目数组,循环遍历每个锯齿状数组,如果值不存在,则添加它们。然后一个简单的计数将返回唯一数量的值。但是,想知道是否有更好的解决方案。

db.MyObjects.Where(t => !String.IsNullOrEmpty(t.MyProperty))
    .Select(t => t.Categories.Split(new char[] { ' ' },
        StringSplitOptions.RemoveEmptyEntries))
    .ToArray()

下面是一个更易读的例子:

array[0] = { "v1", "v2", "v3" }
array[1] = { "v1" }
array[2] = { "v4", "v2" }
array[3] = { "v1", "v5" }

从所有值中,唯一项是v1v2v3v4v5

唯一项目的总数为5

是否有可能使用 linq 的解决方案,它仅返回唯一值或返回唯一值的数量?

4

2 回答 2

8

是的,使用 LINQ,这非常简单。首先用于SelectMany将锯齿状数组展平为IEnumerable<string>包含所有值的数组,然后调用Distinct以仅选择唯一值:

IEnumerable<string> uniqueValues = array.SelectMany(x => x).Distinct();

如果您想计算它们,请使用Count

IEnumerable<string> uniqueValues = array.SelectMany(x => x).Distinct();
int uniqueCount = uniqueValues.Count();
于 2010-04-04T23:19:53.863 回答
5

查询表达式方法是

var query = (from arr in array
             from value in arr
             select value).Distinct();
于 2010-04-04T23:21:06.163 回答