LINQ를 사용하여 컬렉션의 마지막 N 요소를 검색하는 방법
컬렉션의 마지막 N 요소를 얻기 위해 LINQ는 효율적인 Skip() 메서드. Math.Max()를 통해 조건문과 결합하면 음수 입력으로 인한 오류를 피할 수 있습니다.
collection.Skip(Math.Max(0, collection.Count() - N));
이 접근 방식은 정렬을 사용하지 않고 원래 항목 순서를 유지하며 여러 LINQ 공급자와 호환됩니다. .
더 많은 유연성을 위해 제공된 확장 메소드는 위의 내용을 캡슐화합니다. 논리:
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)); } }
사용법:
collection.TakeLast(5);
Count() 호출은 특정 데이터 구조에 대한 열거를 발생시키지만 목록 및 배열과 같은 일반적인 데이터 구조에 대한 최적화가 존재합니다. 순방향 열거형의 경우 대체 1패스 알고리즘(예: Lasse V. Karlsen 또는 Mark Byers)을 사용하면 데이터에 대한 다중 패스를 피할 수 있습니다.
위 내용은 LINQ를 사용하여 컬렉션의 마지막 N개 요소를 효율적으로 가져오는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!