Maison >développement back-end >C++ >Comment obtenir efficacement les N derniers éléments d'une collection à l'aide de LINQ ?

Comment obtenir efficacement les N derniers éléments d'une collection à l'aide de LINQ ?

Linda Hamilton
Linda Hamiltonoriginal
2025-01-05 04:21:38467parcourir

How to Efficiently Get the Last N Elements of a Collection Using 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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn