> 백엔드 개발 > 파이썬 튜토리얼 > Python에서 반복자가 불규칙하게 중첩된 목록을 어떻게 효율적으로 평면화할 수 있습니까?

Python에서 반복자가 불규칙하게 중첩된 목록을 어떻게 효율적으로 평면화할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-12-24 22:35:10
원래의
686명이 탐색했습니다.

How Can Iterators Efficiently Flatten Irregularly Nested Lists in Python?

반복자를 사용하여 불규칙한 목록 목록 병합

중첩 목록을 병합하는 기존 솔루션이 [[[1, 2, 3], [와 같은 구조에서는 실패한다고 언급하셨습니다. 4, 5]], 6]. 이 쿼리는 특히 반복자를 사용하는 대체 접근 방식의 타당성을 탐구합니다.

제안된 접근 방식:

제안 솔루션에는 생성기 기능을 활용하여 평면화 프로세스를 단순화하고 성능을 향상시키는 것이 포함됩니다. .

파이썬 2 구현:

from collections import Iterable

def flatten(xs):
    for x in xs:
        if isinstance(x, Iterable) and not isinstance(x, basestring):
            for item in flatten(x):
                yield item
        else:
            yield x
로그인 후 복사

Python 3 구현:

from collections.abc import Iterable

def flatten(xs):
    for x in xs:
        if isinstance(x, Iterable) and not isinstance(x, (str, bytes)):
            yield from flatten(x)
        else:
            yield x
로그인 후 복사

반복자의 장점:

  • 반복자는 한 번에 하나씩 항목을 느리게 생성하여 메모리를 절약합니다. 전체 평면화된 목록을 저장하는 대신 시간을 지정합니다.
  • 반복자는 중복 값을 생성하는 대신 원래 요소에 대한 참조를 제공하여 복사를 방지합니다.
  • 반복자는 생성기 함수가 중첩 탐색을 위한 논리 구조.

결론:

반복자를 활용하여 제안된 접근 방식은 불규칙한 목록을 평면화하는 효과적이고 효율적인 방법을 제공합니다. 다른 방법과 비교하여 임의의 중첩 깊이가 있는 사례를 해결하고 재귀 또는 수동 병합 기술의 단점을 방지합니다.

위 내용은 Python에서 반복자가 불규칙하게 중첩된 목록을 어떻게 효율적으로 평면화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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