首頁 >後端開發 >Python教學 >如何使用遞歸和基於生成器的方法在 Python 中有效地展平不規則巢狀清單?

如何使用遞歸和基於生成器的方法在 Python 中有效地展平不規則巢狀清單?

DDD
DDD原創
2024-12-28 03:19:15323瀏覽

How Can Irregularly Nested Lists Be Efficiently Flattened in Python Using Recursive and Generator-Based Approaches?

展平不規則巢狀清單清單

展平巢狀清單清單的任務可能具有挑戰性,尤其是當巢狀不規則時。所提出的問題研究了以下扁平化演算法的功效:

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 與3 的範例:

Python 2

利用Python 2.6 中引入的Iterable ABC:

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

Python 3from 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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn