Maison >développement back-end >C++ >Comment obtenir efficacement les N derniers éléments d'une collection à l'aide de LINQ ?
Comment récupérer les N derniers éléments d'une collection à l'aide de LINQ
Pour obtenir les N derniers éléments d'une collection, LINQ propose l'outil efficace Méthode Sauter(). En le combinant avec une instruction conditionnelle via Math.Max(), nous pouvons éviter les erreurs provenant d'une entrée négative.
collection.Skip(Math.Max(0, collection.Count() - N));
Cette approche préserve l'ordre d'origine des éléments sans recourir au tri et est compatible avec plusieurs fournisseurs LINQ. .
Pour plus de flexibilité, la méthode d'extension fournie encapsule ce qui précède logique :
public static class MiscExtensions { public static IEnumerable<T> TakeLast<T>(this IEnumerable<T> source, int N) { return source.Skip(Math.Max(0, source.Count() - N)); } }
Utilisation :
collection.TakeLast(5);
Bien que l'appel Count() entraîne une énumération pour certaines structures de données, des optimisations existent pour les plus courantes comme les listes et les tableaux. Pour les énumérables avant uniquement, les algorithmes alternatifs à un seul passage (par exemple, de Lasse V. Karlsen ou Mark Byers) évitent les passages multiples sur les données.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!