问题描述
在.NET/C#应用程序编程开发中,如何判断一个字符串集合List<string>
中是否有重复的元素?php
假若有以下的List<string>集合:html
var lstNames = new List<string> { "A", "B", "A","C" };
var lstNames = new List<string> { "A", "B", "A","C" };
如今有一个简单的判断/检查lstNames
字符串集合中是否有重复元素的实现,以下:java
if (lstNames.Distinct().Count() != lstNames.Count()) { Console.WriteLine("List contains duplicate values."); }
在.NET/C#应用程序编程开发中,是否还有更好的实现方式,来检查/判断一个字符串集合中是否有重复元素呢?if (lstNames.Distinct().Count() != lstNames.Count()) { Console.WriteLine("List contains duplicate values."); }
方案一
使用LINQ
的GroupBy()
和Any()
方法实现,以下:编程
lstNames.GroupBy(n => n).Any(c => c.Count() > 1);
post
方案二
使用循环和一个HashSet
来实现,以下:this
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<T>
进行扩展的静态扩展方法,以下:spa
public static bool AreAnyDuplicates<T>(this IEnumerable<T> list) { var hashset = new HashSet<T>(); return list.Any(e => !hashset.Add(e)); }
public static bool AreAnyDuplicates<T>(this IEnumerable<T> list) { var hashset = new HashSet<T>(); return list.Any(e => !hashset.Add(e)); }