>백엔드 개발 >C++ >LINQ는 어떻게 C# 목록에서 중복 개체를 효율적으로 계산하고 요약할 수 있습니까?

LINQ는 어떻게 C# 목록에서 중복 개체를 효율적으로 계산하고 요약할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-03 02:25:38960검색

How Can LINQ Efficiently Count and Summarize Duplicate Objects in a C# List?

LINQ 및 C를 사용한 중복 항목 계산

데이터 조작 영역에서는 특정 기준에 따라 데이터를 집계해야 하는 경우가 많습니다. 개체 목록 내에서 중복 항목을 계산해야 할 때 이러한 상황이 발생합니다. LINQ(Language Integrated Query)는 이 작업에 대한 우아한 솔루션을 제공합니다.

문제: 중복 개체 요약

초기 쿼리:

var q = from x in inventory
                 group x by x into g
                 let count = g.Count()
                 orderby count descending
                 select new { Count = count, gameName = g.Key.gameName, gameID = g.Key.gameID };

이 쿼리는 개수와 각 복제본의 이름을 지정하면 게임 ID가 생략됩니다. 이 문제를 해결하려면 접근 방식을 수정해야 합니다.

해결책: 사용자 지정 그룹화 및 선택

개체 속성별 그룹화:

var q = from x in inventory
                 group x by x.gameName into g
                 let count = g.Count()
                 orderby count descending
                 select new { Count = count, gameName = g.Key, gameID = g.First().gameID };

게임 이름을 기준으로 개체를 그룹화합니다. 속성을 사용하여 동일한 이름의 개체를 효과적으로 집계합니다.

첫 번째 개체 선택 ID:

gameID = g.First().gameID

동일한 이름을 가진 개체는 서로 다른 ID를 가질 수 있으므로 First()를 사용하여 그룹에 있는 첫 번째 개체의 ID를 검색합니다. 이를 통해 각각의 고유한 게임 이름에 대한 ID를 갖게 됩니다.

전체 예:

완성된 코드 조각 내에 위의 논리를 캡슐화:

var inventory = new List<game>();

// ... additional code for populating the inventory list

var q = from x in inventory
                 group x by x.gameName into g
                 let count = g.Count()
                 orderby count descending
                 select new { Count = count, gameName = g.Key, gameID = g.First().gameID };

// ... additional code for displaying the results

이제 쿼리는 각 고유 게임 이름에 대한 개수, 게임 이름 및 게임 ID를 중복 횟수가 가장 높은 순서대로 올바르게 표시합니다.

위 내용은 LINQ는 어떻게 C# 목록에서 중복 개체를 효율적으로 계산하고 요약할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.