Apa cara paling efisien untuk menyimpan daftar string yang mengabaikan duplikat? Saya berpikir kamus mungkin paling baik memasukkan string dengan menulis dict [str] = false; dan menghitung melalui tombol sebagai daftar. Apakah itu solusi yang bagus?
86
HashSet
akan kehilangan urutan item. Sebuah fitur aList
menyediakan.Anda dapat melakukan sesuatu seperti ini
var hash = new HashSet<string>(); var collectionWithDup = new []{"one","one","two","one","two","zero"}; // No need to check for duplicates as the Add method // will only add it if it doesn't exist already foreach (var str in collectionWithDup) hash.Add(str);
sumber
Saya tidak yakin apakah ini dianggap sebagai jawaban yang baik, tetapi ketika dihadapkan dengan kebutuhan akan rangkaian unik yang mempertahankan urutan penyisipan, saya berkompromi dengan HashSet dan Daftar secara berdampingan. Dalam kasus ini, setiap kali Anda menambahkan ke set, lakukan hal berikut:
if(hashSet.Add(item)) orderList.Add(item);
Saat menghapus item, pastikan untuk menghapusnya dari keduanya. Jadi, selama Anda dapat yakin bahwa tidak ada item lain yang ditambahkan ke daftar, Anda akan memiliki set unik berurutan penyisipan!
sumber
Anda juga bisa menggunakan Linq seperti pada:
using System.Linq; var items = new List<string>() { "one", "one", "two", "one", "two", "zero" }; List<string> distinctItems = items.Distinct().ToList();
sumber
Gunakan HashSet, tidak perlu memeriksa .Contains (), cukup tambahkan item Anda dalam daftar dan jika duplikatnya tidak akan menambahkannya.
HashSet<int> uniqueList = new HashSet<int>(); uniqueList.Add(1); // List has values 1 uniqueList.Add(2); // List has values 1,2 uniqueList.Add(1); // List has values 1,2 Console.WriteLine(uniqueList.Count); // it will return 2
sumber
Ini bukan bagian dari namespace sistem tetapi telah menggunakan Iesi.Collections dari http://www.codeproject.com/KB/recipes/sets.aspx dengan NHibernate. Ini memiliki dukungan untuk set hash bersama dengan set yang diurutkan, set kamus, dan sebagainya. Karena telah digunakan dengan NHibernate, ini telah digunakan secara ekstensif dan sangat stabil. Ini juga tidak membutuhkan .Net 3.5
sumber
Berikut adalah solusi lain tanpa menggunakan
HashSet
.var items = new List<string>() { "one", "one", "two", "one", "two", "zero" }; var uniqueItems = items.Where((item, index) => items.IndexOf(item) == index);
Itu diadopsi dari utas ini: javascript - Nilai unik dalam larik
Uji:
using FluentAssertions; uniqueItems.Count().Should().Be(3); uniqueItems.Should().BeEquivalentTo("one", "two", "zero");
Uji kinerja untuk
List
,HashSet
danSortedSet
. 1 juta iterasi:Uji kode sumber (intisari)
sumber