Python에서 목록이 항목을 공유하는지 확인하는 방법: 모범 사례 및 성능 비교

Patricia Arquette
풀어 주다: 2024-10-20 08:06:02
원래의
189명이 탐색했습니다.

How to Check if Lists Share Any Items in Python: Best Practices and Performance Comparison

Python에서 목록이 항목을 공유하는지 테스트

Python 개발자는 두 목록에 겹치는 요소가 포함되어 있는지 확인해야 하는 경우가 많습니다. 중첩 루프를 사용하는 간단한 접근 방식이 있지만 더 효율적이고 Python 방식의 방법도 사용할 수 있습니다.

일반적인 접근 방식:

  1. 교차점 설정: 두 목록을 모두 집합으로 변환하고 교차점을 확인합니다. 평균 O(n m)이지만 세트 생성이 필요하며 해싱 충돌이 발생할 수 있습니다.
  2. 생성기 표현식: 한 목록을 반복하면서 다른 목록의 멤버십을 테스트합니다. 시작 부분에 공유 요소가 있는 목록에 효율적입니다.
  3. 하이브리드 접근 방식: 하나의 목록을 집합으로 변환하고 해당 목록의 멤버십을 테스트합니다. 집합과 생성기 표현식의 이점을 결합합니다.
  4. isdisjoint() 메서드: 두 집합(목록에서 생성됨)에 분리된 요소가 있는지 확인합니다. 작은 목록과 공유 요소가 시작 부분에 있는 경우에 적합합니다.

성능 분석:

이러한 방법의 성능은 목록 크기와 공유 요소의 위치.

최상의 접근 방식:

대부분의 경우 속도와 효율성 때문에 isdisjoint() 메서드를 사용하는 것이 좋습니다. 특히 목록이 작은 경우에는 더욱 그렇습니다. 또는 공유 요소가 시작 부분에 있습니다. 그러나 생성기 표현식은 시작 부분에 공유 요소가 있는 대규모 목록에서 더 나은 성능을 발휘할 수 있습니다.

위 내용은 Python에서 목록이 항목을 공유하는지 확인하는 방법: 모범 사례 및 성능 비교의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!