Adakah .NET Mempunyai Kaedah Terbina dalam untuk Memeriksa sama ada Satu Senarai Mengandungi Semua Item dalam Yang Lain?
Masalah:
Anda mempunyai kaedah (ContainsAllItems) yang menentukan sama ada Senarai a mengandungi semua unsur Senarai b. Anda tertanya-tanya sama ada fungsi ini sudah terbina dalam .NET, berpotensi menduplikasi usaha anda.
Jawapan:
Ya, dalam .NET 3.5 dan lebih baru, anda boleh menggunakan mengikuti kaedah:
public static class LinqExtras { public static bool ContainsAllItems<T>(this IEnumerable<T> a, IEnumerable<T> b) { return !b.Except(a).Any(); } }
Penggunaan:
List<int> a = new List<int>() { 1, 2, 3, 4 }; List<int> b = new List<int>() { 2, 3 }; bool result = a.ContainsAllItems(b); // True
Kaedah ini melakukan perbezaan yang ditetapkan antara b dan a (b.Kecuali(a)), yang mengembalikan unsur dalam b yang bukan dalam a. Kaedah Any() kemudiannya digunakan untuk menyemak sama ada terdapat sebarang elemen dalam perbezaan set, dan hasilnya disongsangkan untuk menentukan sama ada a mengandungi semua item dalam b.
Nota:
Kaedah ContainsAllItems asal juga merupakan penyelesaian yang sah tetapi kurang cekap sedikit daripada pendekatan menggunakan LINQ. Versi LINQ mengambil kesempatan daripada penilaian malas, berpotensi melakukan kurang kerja jika senarai mempunyai bilangan item yang banyak.
Atas ialah kandungan terperinci Adakah .NET Menawarkan Cara Terbina dalam untuk Memeriksa sama ada Satu Senarai Mengandungi Semua Elemen Yang Lain?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!