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

Python에서 어떻게 임의로 중첩된 목록을 효율적으로 평면화할 수 있습니까?

DDD
DDD원래의
2024-12-28 16:04:11388검색

How Can We Efficiently Flatten Arbitrarily Nested Lists in Python?

임의로 중첩된 목록 평면화

다양한 깊이 수준의 중첩 목록은 이를 단일 차원으로 줄이는 데 어려움을 겪습니다. 얕은 목록을 평면화하는 솔루션은 많지만 [[[1, 2, 3], [4, 5]], 6]과 같이 불규칙하게 중첩된 목록으로 인해 많은 어려움을 겪고 있습니다.

재귀 접근 방식

질문에서 언급한 한 가지 접근 방식은 다음과 같습니다. 재귀:

def flatten(x):
    result = []
    for el in x:
        if hasattr(el, "__iter__") and not isinstance(el, basestring):
            result.extend(flatten(el))
        else:
            result.append(el)
    return result

이 알고리즘은 목록을 반복하여 중첩된 목록을 재귀적으로 평면화하고 반복할 수 없는 요소를 결과에 추가합니다.

가독성 및 성능 향상을 위한 생성기 함수

생성기 기능은 가독성과 효율성을 모두 향상시킬 수 있는 대체 접근 방식을 제공합니다.

Python 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 3에서는 Yield from 연산자는 중첩된 생성기의 항목을 순차적으로 편리하게 반환하는 반면, Python 2에서는 하위 생성기를 통해 명시적으로 반복합니다.

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

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