问题描述
在.NET/C#应用程序编程开发中,如何判断一个字符串集合List
中是否有重复的元素?
假如有如下的List
var lstNames = new List { "A", "B", "A","C" };
现在有一个简单的判断/检查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" ,"C"}; var hashset = new HashSet<string>(); foreach(var name in lstNames) { if (!hashset.Add(name)) { Console.WriteLine("List contains duplicate values."); break; } }
方案三
以下是一个基于HashSet
进行扩展的静态扩展方法,如下:
public static bool AreAnyDuplicates(this IEnumerable list)
{
var hashset = new HashSet(); return list.Any(e => !hashset.Add(e)); }