问题描述
在.NET/C#应用程序编程开发中,如何判断一个字符串集合List<string>
中是否有重复的元素?
假如有如下的List<string>集合:
var lstNames = new List<string> { "A", "B", "A" };
现在有一个简单的判断/检查lstNames
字符串集合中是否有重复元素的实现,如下:
if (lstNames.Distinct().Count() != lstNames.Count())
{
Console.WriteLine("List contains duplicate values.");
}
在.NET/C#应用程序编程开发中,是否还有更好的实现方式,来检查/判断一个字符串集合中是否有重复元素呢?
方案一
使用LINQ
的GroupBy()
和Any()
方法实现,如下:
lstNames.GroupBy(n => n).Any(c => c.Count() > 1);
方案二
使用循环和一个HashSet
来实现,如下:
var lstNames = new List<string> { "A", "B", "A" };
var hashset = new HashSet<string>();
foreach(var name in lstNames)
{
if (!hashset.Add(name))
{
Console.WriteLine("List contains duplicate values.");
break;
}
}
方案三
以下是一个基于HashSet<T>
进行扩展的静态扩展方法,如下:
public static bool AreAnyDuplicates<T>(this IEnumerable<T> list)
{
var hashset = new HashSet<T>();
return list.Any(e => !hashset.Add(e));
}
版权声明:本作品系原创,版权归码友网所有,如未经许可,禁止任何形式转载,违者必究。
发表评论
登录用户才能发表评论, 请 登 录 或者 注册