如何判斷/檢查一個集合(List )中是否有重復的元素


問題描述

在.NET/C#應用程序編程開發中,如何判斷一個字符串集合List<string>中是否有重復的元素?

假如有如下的List<string>集合:

var lstNames = new List<string> { "A", "B", "A","C" };

現在有一個簡單的判斷/檢查lstNames字符串集合中是否有重復元素的實現,如下:

if (lstNames.Distinct().Count() != lstNames.Count()) { Console.WriteLine("List contains duplicate values."); }

在.NET/C#應用程序編程開發中,是否還有更好的實現方式,來檢查/判斷一個字符串集合中是否有重復元素呢?

方案一

使用LINQGroupBy()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<T>進行擴展的靜態擴展方法,如下:

public static bool AreAnyDuplicates<T>(this IEnumerable<T> list) { var hashset = new HashSet<T>(); return list.Any(e => !hashset.Add(e)); }







 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM