如何判断/检查一个集合(List)中是否有重复的元素

问题描述

在.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."); }

方案一

使用LINQGroupBy()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)); }







  

转载于:https://www.cnblogs.com/Artist007/p/10973883.htmlcode