我想知道如何统计不规则数组中唯一值的数量。
我的域对象包含一个字符串属性,其中包含以空格分隔的值。
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" }
从所有的值中,唯一的项目是v1、v2、v3、v4和v5。
唯一项的总数为5。
有没有解决方案,可能使用linq,只返回唯一的值或返回唯一值的数量?