ホームページ > バックエンド開発 > Python チュートリアル > Python で順列を生成するにはどうすればよいですか?

Python で順列を生成するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-24 04:58:31
オリジナル
848 人が閲覧しました

How Can I Generate Permutations in Python?

Python ライブラリを使用した順列の生成

Python でリストのすべての順列を生成するには、次の itertools.permutations 関数を利用する便利な方法があります。標準ライブラリ。例:

import itertools
list(itertools.permutations([1, 2, 3]))
ログイン後にコピー

順列のカスタム実装

または、順列を計算するカスタム実装を作成できます:

def permutations(elements):
    if len(elements) <= 1:
        yield elements
        return
    for perm in permutations(elements[1:]):
        for i in range(len(elements)):
            yield perm[:i] + elements[0:1] + perm[i:]
ログイン後にコピー

その他アプローチ

必要に応じて、次のアプローチを検討することもできます:

# Using reversed indices
def permutations(iterable, r=None):
    pool = tuple(iterable)
    n = len(pool)
    r = n if r is None else r
    if r > n:
        return
    indices = range(n)
    cycles = range(n, n-r, -1)
    yield tuple(pool[i] for i in indices[:r])
    while n:
        for i in reversed(range(r)):
            cycles[i] -= 1
            if cycles[i] == 0:
                indices[i:] = indices[i+1:] + indices[i:i+1]
                cycles[i] = n - i
            else:
                j = cycles[i]
                indices[i], indices[-j] = indices[-j], indices[i]
                yield tuple(pool[i] for i in indices[:r])
                break
        else:
            return

# Using product
def permutations(iterable, r=None):
    pool = tuple(iterable)
    n = len(pool)
    r = n if r is None else r
    for indices in product(range(n), repeat=r):
        if len(set(indices)) == r:
            yield tuple(pool[i] for i in indices)
ログイン後にコピー

以上がPython で順列を生成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート