问题描述

在.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 { "A", "B", "A" ,"C"};

var hashset = new HashSet();

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));

}

作者:大艺术家007

Logo

前往低代码交流专区

更多推荐