목록에서 중복 요소 제거
목록에서 중복 요소를 식별하고 제거하는 것은 프로그래밍의 기본 작업입니다. 이 기사에서는 순서 보존과 솔루션의 효율성을 모두 고려하여 이를 달성하기 위한 다양한 방법을 살펴봅니다.
효율적인 중복 제거를 위한 세트 사용
간단하고 효율적인 목록에서 중복 항목을 제거하는 방법은 목록을 집합으로 변환하는 것입니다. 세트는 고유한 요소를 순서 없이 모아 놓은 것입니다. 목록을 세트로 변환하면 모든 중복 항목이 자동으로 제거됩니다. 중복 없이 목록을 다시 생성하려면 수정된 집합을 list() 함수를 사용하여 다시 목록으로 변환할 수 있습니다.
아래 예를 고려하세요.
t = [1, 2, 3, 1, 2, 3, 5, 6, 7, 8] unique_list = list(set(t))
결과인 Unique_list는 [1, 2, 3, 5, 6, 7, 8]이 되고, 모두 중복됩니다. 삭제되었습니다.
OrderedDict 또는 사전을 사용하여 순서 유지
요소의 원래 순서를 유지하는 것이 중요한 경우 세트는 순서가 지정되지 않은 컬렉션이므로 사용할 수 없습니다. 대신 OrderedDict 또는 사전을 사용하여 삽입 순서를 유지할 수 있습니다.
OrderedDict 사용:
from collections import OrderedDict ordered_unique_list = list(OrderedDict.fromkeys(t))
사전 사용(Python 3.7 이상):
unique_list = list(dict.fromkeys(t))
두 접근 방식 모두 원본을 유지하면서 중복 항목이 제거된 목록을 반환합니다.
성능 고려 사항
목록을 집합으로 변환했다가 다시 목록으로 변환하는 것은 효율적이지만 추가 오버헤드가 발생할 수 있습니다. 순서가 중요하지 않은 경우 일반적으로 속도와 다양성을 위해 세트를 사용하는 것이 좋습니다. 그러나 순서를 유지해야 하는 경우 OrderedDict 또는 사전 접근 방식이 실행 가능한 옵션을 제공합니다.
해싱할 수 없는 항목 처리
세트, OrderedDict 및 사전 솔루션에서는 목록의 요소가 해시 가능해야 합니다. 해시할 수 없는 요소(예: 목록)의 경우 각 요소를 다른 모든 요소와 비교하려면 중첩 루프를 사용하는 더 느린 접근 방식이 필요합니다.
위 내용은 순서를 유지하거나 무시하면서 Python의 목록에서 중복 항목을 효율적으로 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!